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(57) Abstract 

The invention relates to a bus system for 
DFPs DE 16 88 A 1 and to building blocks with two 
dimensional or multidimensional programmable 
cell structures (of type FPGA, DPGA or the like), 
characterized in that a) the bus system comprises a 
plurality of electrically independent bus segments 
disconnected by nodes, b) the nodes actively 
connect or disconnect bus segments, whereby bl) 
several bus segments are joined and connected by 
gates to a bus bar located inside the node or b2) 
connection occurs directly via circuitry elements, 
drivers and/or registers, c) each node has a routing 
table where information on the structure of the 
connection is stored, d) each node has a monitoring 
unit, which verifies independently if a connection 
can be established or not. 

(57) Zusammenfassung 

Ein Bussystem fur DFPs gemafi DE 44 
16 881 Al, sowie Bausteine mit zwei- oder 
mehrdimensionaler programmierbarer Zellstruktur (der Gattungen FPGA, DPGA, o.dgl.) ist dadurch gekennzeichnet, daB a) das Bussystem 
aus einer Vielzahl voneinander elektrisch unabhSngiger Bussegmente besteht, die uber Knoten getrennt sind, b) die Knoten Bussegmente 
aktiv zusammenfugen oder trennen, wobei bl) entweder zum Zusammenfugen mehrere Bussegmente uber Tore auf eine, sich innerhalb 
des Knoten befindende Sammelschienen zusammengeschaltet werden, oder b2) die ZusammenfQgung direkt uber Schaltelemente, Treiber 
undVoder Register erfolgt, c) jeder Knoten eine Routingtabelle besitzt, in der die Informationen uber den Aufbau der Verbindungen gespeichert 
sind, d) jeder Knoten eine Oberwachungseinheit besitzt, die selbstandig prilft, ob eine Verbindung aufgebaut werden kann oder nicht 
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Internes Bussystem fur DFPs, sowie Bausteinen mit zwei- oder 
mehrdimensionalen programmierbaren Zellstrukturen, zur 
Bewaltigung grofier Datenmengen mit hohem Vernetzungsaufwand. 

Hintergrund der Erfindung 
Stand der Technik 

... in Systemen mit zwei- oder mehrdimensionalen 
programmierbaren Zellstrukturen ( FPGAs , DPGAs) 
In FPGAs und DPGAs befinden sich interne Bussysteme, die 
entweder global Anschlufi an alle oder eine grolie Menge von 
Logikzellen haben oder eine lokale NextNeighbour-Verbindung 
aufweisen. Beiden Arten ist gemeinsam, daft es sich urn direkte 
Verbindungen zwischen zwei oder mehreren Logikzellen handelt. 
Weiterhin kann immer genau ein Signal den Bus benutzen, es sei 
denn, dali eine Multiplexerstruktur in eine Mehrzahl von 
Logikzellen zusammen mit einer Steuerung konfiguriert wird. 

... in DFP-basierenden Systemen 

In DFP-basierenden Systemen, nach DE 44 16 881 existieren die 
selben bereits beschriebenen Bussysteme. Zusatzlich existiert 
die Moglichkeit ein Bussystem zu trennen, so daft mehrere 
getrennt nutzbare Teilbusse entstehen. 

... in IO-Bussysteme nach DE 196 54 595.1-53 
In DE 196 54 595.1-53 wird ein IO-Bussystem beschrieben, das 
eine Vielzahl Bausteininterner Bussysteme, wobei ein Baustein 
ein FPGA, DPGA, DFP oder ahnlicher sein kann, zusammenf afit und 
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aus dem Baustein herausfUhrt. Dabei konnen Speicherbaugruppen 
oder Peripherie oder weitere Bausteine oben genannter Gattung 
angesteuert werden. Es existiert nur ein Adressregister, bzw. 
ein Adresszahler urn die externen Adressen zu generieren. 

Probleme 

Die ublichen Bussysteme sind nicht dazu geeigner grofte 
Datenmengen in Form von byteweise oder anders gruppierten 
Signalen zu ubertragen. Besonders wenn die Bausteine zur 
Berechnung von Algorithmen verwendet werden ist es 
erforderlich, dafi eine Vielzahl von Daten (paketen) 
gleichzeitig zwischen den einzelnen konf igurierten 
Funktionsbereichen eines Bausteines ubertragen werden. In der 
ublichen Technik muB fur jeden Datenpfad, das ist die 
Verbindung (der Bus) zweier (oder mehrerer) Funktionsblocke, 
die dieselben Daten erhalten, eine direkte Punkt zu Punkt 
Verbindung aufgebaut werden, die dann ausschliefilich den 
Datenverkehr zwischen eben diesen Funktionsblocken regelt. Es 
kann sich immer genau ein Datenpaket auf dem Bus befinden. Der 
Vernetzungsaufwand wird extrem hoch. Die Geschwindigkeit der 
heutigen internen Busse wird begrenzt durch die maximaie 
Busbreite und die Laufzeit der Signale auf dem Bus. 
Beim in DE 196 54 595.1-53 beschriebenen IO-Bus kann pro 10- 
Zelle nur eine Art von Busverbindung aufgebaut werden, namlich 
ausschliefilich die in dem Adressregister programmierte . Es 
besteht keine Moglichkeit auf verschiedene Datentypen oder 
Datensender zu reagieren und diese mit verschiedenen externen 
Bausteinen zu verbinden. 
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Verbesserung durch die Erfindung, Aufgabe 
Ziel der Erfindung ist es, ein Bussystem zu schaffen, das 
Daten zwischen einer Vielzahl von Funktionsblocken ubertragen 
kann, wobei sich mehrere Datenpakete gleichzeitig auf dem Bus 
befinden konnen. Dabei erkennt das Bussystem fur verschiedene 
Datentypen oder Datensender automatisch die. richtige 
Verbindung und baut diese auf. 

Die Einzelheiten und besondere Ausgestaltungen, sowie Merkmale 
des erf indungsgemaften Bussystems sind Gegenstand der 
Patentanspruche . 

Beschreibung der Erfindung 

Obersicht uber die Erfindung, Abstrakt 

Beschrieben wird ein Bussystem, das horizontal, vertikal, 
diagonal oder in jeder beliebigen Lage auf einem Baustein 
integriert werden kann. 

Das Bussystem ist in eine Vielzahl von Segmenten unterteilt, 
wobei die Trennung der Segmente durch eine Bussteuerschaltung 
erfolgt. Diese Bussteuerschaltung wird Knoten genannnt. 
Gleichzeitig ubernimmt der Knoten das Routen, also das Steuern 
der Fluftrichtung der Daten. Logikzellen oder PAE-Zellen nach 
DE 196 51 075.9-53 sind an die Knoten angeschlossen, sie 
senden und empfangen ihre Daten uber die Knoten, wobei jedem 
Datenpaket eine Zieladresse mitgegeben werden kann. Ebenfalls 
ist das Bussystem in der Lage uber LookUp-Tabellen, im 
Folgende Routingtabellen genannt, Zieladressen zu generieren^ 
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hierzu kann vor allem das in DE 196 54 846.2-53 beschriebene 
Verfahren dienen. Die Bussysteme sind besonders zu einem 
direkten AnschluB an die in DE 196 54 595.1-53 beschriebenen 
INPUT- /OUTPUT-CELLs geeignet. Das Auf- und Abbauen von 
Verbindungen, sowie die Synchronisation der Daten erfolgt 
automatisch. Schlagt ein Aufbau fehl, da das benotigte 
Bussegment momentan belegt ist, wird der Aufbau zu einem 
spateren Zeitpunkt wiederholt. Anhand unterschiedlicher 
Datentypen oder Datensender konnen automatisch 
unterschiedliche Verbindungen aufgebaut werden, 

Detailbeschreibung der Erfindung 
Das Bussystem 

Auf einem Baustein befinden sich eine Vielzahl von Bussen, die 
horizontal, vertikal, diagonal oder in jeder beliebigen Lage 
auf dem Baustein angeordnet sind. Dabei sind die einzelnen 
Busse nicht durchgehend von einer Bausteinkante zur anderen, 
sondern sie sind in eine Mehrzahl von Bussegmenten unterteilt. 
Die Bussegmente werden durch die nachfolgend beschriebenen 
Knoten getrennt. Jedes Bussegment ist unabhangig von den 
anderen nutzbar und verschaltbar , wobei die Verschaltung von 
den Knoten ubernommen wird. Auf dem Bussystem ist kann ein 
eigenes Protokoll implementiert sein, das von den Knoten 
verwaltet wird; ebenfalls ist denkbar, dafl das Protokoll von 
den Zellen, die den Bus benutzen, verwaltet wird und die 
Knoten nur passive Schalter sind. 
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Der Knoten 

Ein Knoten dient der Verschaltung der einzelnen Bussegmente 
miteinander . Ebenfalls wird das Aufschalten der Zellen auf die 
Bussegmente von den Knoten ubernommen. 

In einem Knoten sind die Bussegmente aller Richtungen 
zusammengefuhrt, das bedeutet, 

- in einem zweidimensionalen System werden die Busse aus 4 
Richtungen Norden (N) , Suden (S) , Osten (E) , Westen (W) auf 
den Knoten gefiihrt. 

- in einem dreidimensionalen System werden die Busse aus 6 
Richtungen Norden (N) , Suden (S) , Osten (E) , Westen (W) , Oben 
(T), Unten (B) auf den Knoten gefiihrt. 

- in einem n-dimensionalen System werden die Busse aus n- 
Richtungen (je Dimension existiert ein Richtungsvektor dessen 
Richtung durch das Vorzeichen bestimmt wird pro Dimension 
existieren zwei Richtungen, die durch das Vorzeichen des 
Richtungsvektors unterschieden werden) auf den Knoten gefiihrt. 

Knoten Typ A 

Innerhalb des Knotens befindet sich ein Bussystem, auf das die 
externen Busse auf geschaltet werden und das somit aus mehreren 
Sammelschienen besteht. Ein externer erster Bus wird uber ein 
Tor auf eine Sammelschiene auf geschaltet . Uber ein weiteres 
Tor wird die Sammelschiene auf den externen zweiten Bus 
auf geschaltet . Urn Broadcasting, das Versenden von Daten an 
mehrere Empfanger, zu ermoglichen, konnen auch mehrere 
"zweite" Busse auf das interne Bussystem geschaltet werden. 
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Die Tore konnen dabei als rein passive Schalter, als 
Bustreiber oder als Register/Latch ausgestaltet sein. 

Weiterhin hat der Knoten Zugriff auf eine (oder mehrere) mit 
ihm verbundene (n) konf igurierbaren Elemente (Zellen) . Diese 
verbindet er gegebenenf alls mit einem oder mehreren der 
angrenzenden Bussegmente . 

Knoten Typ B 

Im Gegensatz zum Knoten Typ A existiert kein internes 
Bussystem. Der Knoten besteht aus n konf igurierbaren 
Schaltern, die jedes angrenzende Segment mit jedem anderen 
angrenzenden Segment verbinden konnen. Beispielsweise gilt bei 
2-dimensionalen Strukturen n=6. 



N 


Verbindung 


1 


O-W/W-0 


2 


N-S/S-N 


3 


N-O/O-N 


4 


O-S/S-0 


5 


S-W/W-S 


6 


W-N/N-W 



(N=Nord f 0=Ost, S=Siid, W=West) 

Ein Schalter kann unidirektional oder bidirektional 
ausgestaltet sein, dabei kann er ein Register oder Latch zur 
Speicherung der Daten enthalten. 
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Das "gewohnliche" Routingverf ahren 

Eine Verbindung wird initiiert von einem Datensender (DS) 

dies ist ein konf igurierbares Element (Logikzelle, Buszelle 

(auch Externe gemafi DE 196 54 595.1-53)) , der eine 

Verbindung zu einem Datenempf anger (DE) der ebenfalls aus 

einem konf igurierbaren Element besteht benotigt. Hierzu 

teilt der DS dem Knoten seine Busanf orderung mit. Der erste 
Knoten direkt nach einem Datensender wird Initiator-Knoten 
genannt. Der entnimmt, wie nachfolgend beschrieben, einer 
internen Tabelle die Adresse des nachsten fur den 
Datenrransf ers benotigten Knotens. 

Sofern der Knoten in der Lage ist, das erste benotigte 

Bussegment anzusprechen das ist immer dann moglich, wenn 

das Bussegment UND eine interne Sammelschiene des Knoten frei 

ist baut er die Verbindung auf, ansonsten weist er die 

Anforderung des DS zuruck und der DS versucht den Zugriff zu 
einem spateren Zeitpunkt noch einmal, oder wartet und halt die 
Zugriff sanf orderung weiter aufrecht, bis der Knoten sie 
aktzeptiert . 

Jeder nachfolgende Knoten entnimmt wiederum die Adresse des 
nachsten Knotens aus seiner internen Tabelle und setzt den 
Aufbau der Verbindung fort. Ist der Knoten nicht in der Lage 
den Aufbau der Verbindung durchzuf uhren (entweder ist das 
benotigte Bussegment besetzt oder die Sammelschiene des 
Knotens ist nicht frei) , so kann er entweder in einen 
Wartezustand springen, oder den Aufbau unterbrechen und einen 
Fehler an den Initiator-Knoten zuruckmelden . 
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Erst wenn eine Verbindung komplett aufgebaut ist, werden die 
Datenpakete ubertragen und der Sender erhalt erhalt die 
Quittierungssignale fttr den Datenaustausch (vgl. rACK in DE 
196 51 075,9-53). Dadurch wird der Datentransf er automatisch 
mit den Datensendern synchronistiert . Schlagt der 
Verbindungsaufbau fehl und muJi er zu einem spateren Zeitpunkt 
wiederholt werden, erhalt der Datensender kein 
Quittierungssignal, somit gehen keine Daten verloren. 

1st die Verbindung komplett aufgebaut, bleibt sie so lange 
quasi-permanent (das bedeutet, sie erscheint dem DS und DE wie 
eine airekte Verbindung) stehen, bis der DS die Verbindung 
durch eine Meldung an den Initiator-Knoten wieder auf lost. 
Es ist denkbar ein Timeout-Verf ahren zu implementieren, das 
eine stehende Verbindung nach einer gewissen Zeit unterbricht, 
ins besondere dann, wenn langere Zeit kein Datentransfer 
stattgefunden hat, urn die Bussegmente fur andere Verbindungen 
f reizugeben. 

Das erweiterte Routingverf ahren 

Beim bisher beschriebenen Verbindungsaufbau befinden sich die 
Adressen nur wahrend der Aufbauphase auf dem Bus. Wahrend der 
Datenubertagen werden die Adressen nicht mehr ubertragen. 
Beim Verfahren des erweiterten Verbindungsauf baus laufen die 
Adressen standig auf separaten Leitungen mit den Daten mit. 
Dabei existieren zwei Adressierungsschemata : 
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1. Raumkoordinaten 

Als Adressen werden die Raumkoordinaten des Ziels angegeben. 
Die Raumkoordinaten sind von der gewahlten Dimension des 
Systems abhangig. Beispielsweise benutzt ein 3-dimensionales 
System die Koordinaten X/Y/Z und ein 2-dimensionales X/Y. 
Prinzipiell ist das Verfahren auf ein beliebig dimensionales 
System anwendbar. Jeder Koordinate ist ein Richtungsvektor 
zugeordnet, der angibt, ob sich die Daten/der 
Verbindungsaufbau in positiver oder negativer Richtung 
bewegen/bewegt . 

Die Daten bewegen sich vom Ursprungsknoten in eine der 
eingesteilten Richtungen. Dabei wird die entsprechende 
Richtungskoordinate beim Durchlauf eines Knotens so 
modifiziert, daft 

- bei Bewegung in positiver Richtung 1 subtrahiert wird 

- bei Bewegung in negativer Richtung 1 addiert wird 

Die Zielachse ist erreicht, wenn die Koordinate 0 ist, der 
Zielknoten ist erreicht, wenn alle Koordinaten 0 sind. 

Es ist implementierungsabhangig, ob ein zweier-Komplement 
generiert wird und eine Koordinate als negative Zahl 
dargestellt wird (auf die aufaddiert wird) oder ob von einer 
positiven Zahl subtrahiert wird. Ebenfalls kann auf eine 
positive Zahl so lange aufaddiert werden, bis ein Oberlauf 
generiert wird, der die Zielposition kennzeichnet . 

Es gibt zwei sinnvolle Strategien die Laufrichtung der Daten 
f estzulegen: 
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a. Statisches Verfahren: Die Daten laufen immer in dieselbe 
Richtung, d.h. es wird versucht immer die Richtung 
beizubehalten, so lange, bis ein Richtungswechsel unbedingt 
erforderlich ist. Ein Richtungswechsel ist erf orderlich, wenn 
die aktuelle Richtungskoordinate gleich null ist, d.h. deren 
Zielposition erreicht wird. 

Wird die Zielposition einer Koordinate erreicht, werden die 
Daten in Richtung der Koordinaten bewegt, die ungleich 0 sind. 
Sind alle Koordinaten gleich null, ist der Zielknoten der 
Daten erreicht. 

b. Dynamisches Verfahren. Die Daten werden beliebig in eine 
der mcglichen Richtungen bewegt, wobei die Bewegung immer in 
die vom Richtungsvektor vorgegebene Richtung erfolgt. Dabei 
bedeutet eine beliebige Bewegung, dafi die Daten immer zu dem 
Knoten weitergeleitet werden, zu dem am wenigsten Verkehr 
herrscht. Es wird also versucht immer den Weg der geringsten 
Kollisionen und Blockaden zu gehen. Dadurch kann das Verfahren 
u.U. schneller und bei grofien Systemen geeigneter sein. 

2. Adress-Lookup 

Werden Lookup-Adressen ubertragen, wird der jeweils nachste 
Knoten in jedem Knoten neu bestimmt. Dies geschieht indem in 
den nachfolgend beschriebenen Routingtabellen der Eintrag der 
Lookup-Adresse ausgelesen wird und so die Daten fur das 
nachste Ziel festgelegt werden. Dieses Ablauf ist gleich wie 
im "gewohnlichen" Routing-Verf ahren . 
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Der Vorteil der Raumkoordinaten liegt darin, dafl kein Lookup 
in einer Tabelle benotigt wird und somit weniger 
Verwaltungsaufwand anfallt. 

Der Vorteil des Adress-Lookup liegt in seiner Flexibility und 
der genauen Vorhersagbarkeit der Verbindung. 

Teilweise kann es sinnvoll beide Verfahren miteinander zu 

mischen. Dazu mussen beide Adressen (Raumkoordinaten und 

Lookup-Adressen) gleichzeitig ubertragen werden. 

Sind die Raumkoordinaten nicht null, werden die Daten anhand 

der Raumkoordinaten ubertragen. Sobald die Raumkoordinaten 

null erreichen, wird in der aktuellen Routingtabelle ein 

Lookup an Stelle der Lookup-Adresse durchgef iihrt . 

Dadurch ist flexibel einstellbar uber welchen Segmenten die 

Daten per Lookup-Verf ahren oder Raumkoordinaten-Verf ahren 

ubertragen werden. 

Die Buszustande des erweiterten Routingverf ahrens 
1 . Quasi-permanent 

Eine Verbindung kann ahnlich zum "gewohnlichen" 
Routingverf ahren quasi-permanent aufgebaut werden. Dabei wird 
jeder Knoten, den ein erstes Datum durchlauft permanent gemafl 
den Adressen die die diesem Datum zugeordnet sind 
freigeschaltet . Die Freischaltung bleibt fur alle 
nachfolgenden Daten so lange auf rechterhalten, bis ein Abbruch 
der Verbindung durchgef iihrt wird. Obwohl ein derartiger Aufbau 
im erweiterten Routingverf ahren nicht zwingend notwendig ist, 
bietet er zwei Vorteile: 

i. Die Durchlauf zeit der Daten wird erheblich verringert. 
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ii. Zeitverluste durch Arbitrierung werden vermieden. 

2. Registered 

Dies ist der normale Buszustand. Eingehende Daten werden 
zunachst in einem Register zwischengespeichert . Beim Schreiben 
in das Register, wird ein Quittierungssignal an den sendenden 
Knoten geschickt. Daten werden nur in das Register 
geschrieben, wenn dieses leer ist, d.h. entweder vorher keine 
Daten in das Register geschrieben wurden oder die vorher 
geschriebenen Daten bereits weiterubertragen sind. Ist das 
Register nicht leer, wird so lange gewartet und kein 
Quittierungssignal erzeugt, bis das Register leer ist. Die 
Register werden arbitriert und das Register mit der momentan 
hochsten Prioritat wird ubertragen. Die Arbitrierung und 
Ubertragung findet zyklisch mit jedem Takt statt. Diese 
Methode eignet sich vor allem fur Ubertragungskanale auf denen 
Daten vieler verschiedener Quellen zeitunkritisch ubertragen 
werden miissen. Diese Methode wird quellenoptimiert genannt. 

3. Segmentiert 

Ein segmentierter Obertragungskanal besteht aus quasi- 
permanenten und register-orientierten Knoten. Dabei ist der 
Obertragungskanal stellenweise geschwindigkeitsoptimiert 
quasipermanent und an anderen Stellen quellenoptimiert 
ausgestaltet . 
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Die Routingtabellen 

Grundbaustein eines Knotens ist eine Routing-Tabelle, ahnlich 
der in DE 196 54 846.2-53 beschriebenen Switching-Tabellen . 

Der mogliche Aufbau einer solchen Tabelle ist wird anhand 
eines Ausf uhrungsbeispieles beschrieben: 



Tor 


EALU 


Bus 


Eintrag 
Position 
in 

Zieitabel 
le 


Lauf zeit 


Aufbauzeit 


1 


2 


3 


4 


0 
1 


0 
2 


R 
1 


R 
2 


1 


0 


a. . 0 


b. .0 


c. . 0 











































































































Jede Zeile stellt eine gultige Verbindung dar. Dabei konnen 
mehrere Verbindungen gleichzeitig aktiv sein, maximal so viel 
Verbindungen, wie freie interne Sammelschienen und freie 
externe Bussegmente existieren. Eine nachfolgend beschriebene 
Oberwachungslogik ubernimmt die Prufung, ob eine neu 
ausgewahlte Verbindung aufgebaut werden kann. 
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Jede Zeile wird liber ihre binare Adresse angesprochen und 
ausgewahlt. Weiterhin gibt es Sonderzeilen, die keine binare 
Adresse besitzen, sondern uber Triggerssignale oder 
Zustandssignalen selektiert werden. Zu diesen Signalen gehoren 
(vgl. DE 196 51 075.9-53) 

- rRDYl, rRDYh 

- oACKl, OACK2 

Hierbei werden Busverbindungen zu den Datenempf angern (rRDY) 
automat isch immer dann aufgebaut, wenn die Datensender-Zelle 
gultige Ergebnisse besitzt. Bei den Signalen oACK ist der 
Empfanger-/Senderablauf vertauscht. Der Datenempf anger baut 
die Verbindung zu seinem Datensender auf, sobald der 
Datenempf anger seine Operanden abgearbeitet hat und in der 
Lage ist neue Operanden zu verarbeiten. 

In den Spalten Tor werden die fur die jeweilige Verbindung 
aktiven Tore eingetragen, dabei ist es moglich, dafi nur ein 
Tor markiert ist und in den Spalten EALU eine Verbindung zu 
einem konf igurierbaren Element (einer oder mehrerer Zellen) 
zum Beispiel zu einem R-REG oder O-REG (vgl. DE 196 51 075.9- 
53) gewahlt wird. 

In der Spalte Bus wird die fur diese Verbindung verwendete 
interne Sammelschiene ausgewahlt, dabei ist der Wert binar, so 
daB in der beschriebenen Tabelle insgesamt 4 interne 
Sammelscheinen benutzt werden konnnen. Die Auswahl der 
internen Sammelschienen kann auch entfallen, in dem ein 
Prioritatsdekoder die erste freie Sammelschiene erkennt und 
diese automatisch zuteilt. 
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In der Spalte Eintrag Position in Zieltabelle wird die Adresse 
der Zeile der Tabelle angegeben, die den Knoten steuert, zu 
dem Verbindung auf genommen wird. An dieser Adresse stehen die 
fiir die aktuelle Verbindung benotigten Routinginf ormationen im 
nachsten Knoten. 

Die Spalte Laufzeit ist optional. Darin kann die erwartete 
Signallauf zeit vom DS zum DE angegeben werden. Diese 
Information kann fur Berechungen des Datendurchsat zes oder zur 
Generierung eines Timeout verwendet werden. 

Die Spalte Aufbauzeit ist optional. Darin kann die maximale 
Zeit zum Aufbauen der Verbindung zum nachsten Knoten (oder der 
gesamten Verbindung vom DS zum DE) angegeben werden. Wird 
diese Zeit iiberschritten kann uber einen Timeout der 
Verbindungsaufbau abgebrochen werden und die Bussegmente und 
Knoten werden fiir andere Verbindungen frei. 
Zu einem spateren Zeitpunkt versucht der DS erneut die 
Verbindung herzustellen. 

Die Eintrage in der Routingtabelle konnen gemafl bekannten 
Verfahren (DE 196 51 075.9-53, DE 196 54 846.2-53) von einer 
Ladelogik konfiguriert und umkonf iguriert werden. 

Wird das "erweiterte" Routingverf ahren verwendet, mussen die 
Raumkoordinaten den Routingtabellen hinzugefugt werden. 
Ebenfalls wird eine Prioritatskennung erwartet. 
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Die Prioritatskennung gibt Auskunft, wie relevant ein Kanal 
fur die Leistung eines Bausteines ist. 1st die 
Prioritatskennung sehr hoch, steigt die Relevanz des Kanales. 
Dabei kann die Kennung auf drei Arten ausgelegt werden: 

1 . Timeout 

Die Kennung gibt an, nach wievielen ungenutzten Taktzyklen der 
Kanal abgerissen werden soil, also nach wievielen Zyklen eine 
DISCONNECT generiert wird. 

2. Paket-Grofie 

Die Kennung gibt an, nach wievielen Datenpaketen ein 
DISCONNECT generiert wird. 

3. Takt-Zyklen 

Die Kennung gibt an, nach wievielen Taktzyklen ein DISCONNECT 
generiert wird. 

Dabei kann fest eine der 3 moglichen Arten implementiert 
werden, oder mittels einer zusatzlichen Angabe eine Art 
ausgewahlt werden. 



Die Prioritatsart (Prioart in der nachstehenden Tabelle) wird 
in der nachfolgen beispielsweise aufgefuhrten Routingtabelle 
wie folgt ausgewertet: 



Bit-Kombination 


Prioritatsart 


00 


Timeout 


01 


Paket-GrdJJe 


10 


Takt-Zyklen 


11 


permanent 
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Permanent kann auch dargestellt werden, indem ein Wert der 
Prioritatskennung fest als "permanent" vorgegeben ist. Dafur 
eignet sich fur gewohnlich besonders der Maximalwert der 
Prioritatskennung oder null. 



Tor 


EALU 


Bus 


Eintrag 
Position 
in Ziel- 
tabelle 


Y/X Raum- 
koordinate 

und 
Richtungs- 
vektor 


Prioritats 
-kennung 


Prio 
-art 


1 


2 


3 


4 


0 
1 


0 
2 


R 
1 


R 
2 


1 


0 


k. .0 


m. . 0 


n. .0 


1 


0 



























































































































Der Arbiter 

Der Routingtabelle vorgeschaltet ist ein Arbiter, die aus der 
Menge der Anfragen zum Verbindungsauf bau uber die 
Routingtabelle einige Signale auswahlt. Dabei ist es sinnvoll 
den Arbiter aus einem gewohnlichen Priority-Logik und einem 
sogenannten Round-Robin-Arbiter nach dem Stand der Technik (er 
schaltet die hochste Prioritat auf einer Zeitscheibe immer dem 
nachsten Signal zu, das bedeutet, das Signal, das momentan die 
hdchste Prioritat hat, wird als nachstes die Niederste 
besitzen und dann mit jedem Zugriff eine Hohere erhalten) 
aufzubauen. Dabei kann die Priority-Logik dazu dienen einigen 
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Signalen, wie zum Beispiel rACK, oRDY grundsatzlich eine 

besonders hohe oder besonders niedere Prioritat 

zuzuordnen. Der Round-Robin-Arbiter sorgt dafur, dali ein 
angeforderter Verbindungsaufbau, der soeben nicht aufbaubar 
war, die niederste Prioritat erhalt und somit wartet, bis alle 
anderen Verbindungsanf orderungen entweder aufgebaut oder 
uberpruft wurden. 

Die Zustandsmaschine (Steuerung) 

Eine Zustandsmaschine steuert die internen Ablaufe im Knoten. 
Dabei ist die Zustandsmschine zweigeteilt: 

- Die Steuerung des Knotens 

- Die Steuerung des Bustransfers und der Synchronistation . 
Dabei kann auf eine Zustandsmaschine ahnlich der in DE 196 51 
075.9-53 beschriebenen zuruckgegrif f en werden. 

Die Zustandsmaschine (n) sind gemaft dem Stand der Technik 
implementierbar und werden nicht nahers beschrieben. 

Die Uberwachungseinheit 

Eine Oberwachungseinheit ist der Routingtabelle 
nachgeschaltet . Sie entnimmt die in eine adressierte Zeile 
eingetragenen Daten und uberpruft ob der Verbindungsaufbau 
moglich ist, 

Dabei werden vor allem folgende Punkte uberpruft: 

- Steht eine freie interne Sammelschiene zur Verfugung. 

- Ist das angeforderte Tor frei. 
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- 1st das angeforderte externe Bussegment frei. 

a) 1st die Uberprufung positiv, wird das Signal ACCEPT 
generiert und an die Zustandsmaschinen, sowie die, den 
Verbindungsaufbau anfordernde Einheit, gesendet, um einen 
erf olgreichen Aufbau zu signalisieren. 

b) 1st die Uberprufung negativ, wird das Signal REJECT 
generiert und an die Zustandsmaschinen, sowie die, den 
Verbindungsaufbau anfordernde Einheit, gesendet, um einen 
fehlgeschlagenen Aufbau zu signalisieren. Auf dieses Signal 
kann der oben beschriebene Arbiter reagieren und die Prioritat 
dieser Anforderung auf die Niederste setzen. 

Verbindungsabbau 

Eine bestehende Verbindung kann durch verschiedene Kriterien 
wieder abgebaut werden. Zu den wichtigsten Kriterien zahlen: 
Timeout: Eine Verbindung wird abgebaut, da liber eine langere 
Zeitspanne kein Datentransf er stattgef unden hat. Ein Timeout 
kann einfach uber einen ladbaren Abwartszahler implementiert 
werden. Der Zahler wird bei jedem ubertragenen Datum neu mit 
einem festen Ausgangswert , der die Zeitspannne bis zum Timeout 
reprasentiert, geladen. Findet kein Datentransf er statt, zahlt 
er mit jedem Bustakt um eins herunter. Kommt er bei null an, 
ist die maximale Zeitspanne abgelaufen und der Bus wird 
abgebaut. 

Datenzahler: Ein ladbarer Zahler wird mit der zu iibertragenden 
Anzahl von Daten geladen. Bei jedem Datentransf er zahlt der 
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Zahler um eins herab. Kommt der Zahler bei null an, sind alle 
Daten ubertragen und der Bus wird abgebaut . 

Synchronisationssignale (vgl. DE 197 04 728.9, RECONFIG) : Der 
Busabbau wird durch die Status- und/oder 
Synchronisationssignale der Zelle(n) gesteuert, die als 
Datensender auftreten. Zeigen die Zellen beispielweise an, dafi 
ihre Datenverarbeitung beendet ist oder dafi sie umkonf iguriert 
werden konnen, wird der Bus abgebaut, da er nicht mehr 
benotigt wird. Zu diesen Signalen gehoren auch rRDY, oACK. 

Der Verbindungsabbau geht dabei so vonstatten, dafi vom 
Initiator-Knoten aus ein Signal zum Abbauen der Verbindung 
gesendet wird Jeder weitere Knoten sendet das empfangene 
Signal an seine (n) Partnerknoten weiter und lost die 
Verbindung sofort auf. 

Im erweiterten Routingverf ahren werden quasi-permanente Busse 
entweder durch das RECONFIG-Synchronisationssignal (vgl. DE 
197 04 728.9) oder gemafi der Prioritatskennung abgebaut. Wird 
das Ende einer Verbindung gemaJi der Prioritatskennung von 
einem Knoten f estgestellt , wird von ihm das DISCONNECT- Signal 
zum Abbruch des Busses generiert und an alle anderen Knoten 
weitergeleitet . Die Knoten reagieren auf ein DISCONNECT wie 
auf ein RECONFIG. 

Bei register-orientierten Knoten ist ein Verbindungsabbau 
nicht notwendig, da eine Verbindung dynamisch mit den 
eintref fenden Daten gemafl der zugeordneten Adressen aufgebaut 
wird. Nach dem Weiterleiten der Daten ist die Verbindung 
automatisch abgebaut und fur andere Obertragungen frei. 
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Broadcasting 

In DE 196 51 075.9-53 ist ein Bussystem beschrieben, das das 
Senden eines Datenpaketes an mehrere Empfanger erlaubt und 
ebenfalls eine Quittierung des Datentransf ers ermoglicht. 
Dasselbe System kann bei dem hier beschriebenen Verfahren 
verwendet werden. Es ist ohne weiteres moglich, mehrere Tore 
auf eine Sammelschiene zu schalten. Dabei wird nur eine Zeile 
in der Routingtabelle verwendet. Die Adresse innerhalb der 
Zielroutingtabellen Eintrag Position in Zieltabelle mufi dabei 
bei jeder der selektierten Routingtabellen zwangslaufig 
dieselbe sein. 

Urn dieses Problem zu umgehen, ist es mdglich mehrere Eintrage 
fur als Eintrag Position in Zieltabelle zur Verfugung zu 
stellen. Beispielsweise konnte fur jedes Tor ein separater 
Eintrag Position in Zieltabelle existieren. Damit ist jedem 
Tor eine Adresse innerhalb der Zielroutingtabelle zugeordnet. 

Die Quittierung erfolgt genau wie in DE 196 51 075.9-53 
beschrieben uber Signalleitungen, die von Open-Kollektor- 
Treiber getrieben werden und mit einem Transistor 
abgeschlossen sind. 

Urn eine bessere Implementierbarkeit in existierende Chip- 
Technologien zu ermoglichen konnen Quittierungssignale in 
einem Knoten zunachst maskiert und danach logisch miteinander 
verknupft werden. Die logische Verknupfung wird an den 
nachsten Knoten weitergeleitet . Findet beispielsweise in alien 
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durchlauf enden Knoten eine logische UND-Verknupf ung der 
Quittierungssignale statt, ist das Resultat dasselbe, wie bei 
einer Open-Kollektor-Schaltung. 

Ladelogik (PLU) 

Eine Ladelogik im Sinne von DE 44 16 881 Al ist an die 
Routingtabelle angeschlossen. Ober diese kann die 

Routingtabelle Equivalent zu den Switchingtabellen aus DE 

196 54 846.2-53 konfiguriert und umkonf iguriert werden. 

Die Routingtabellen konnen urn eine Spalte erweitert werden, 
die benutzt wird um Riickmeldungen an die Ladelogik zu senden, 
wenn die in der betreffenden Zeile angegebene Verbindung auf- 
oder abgebaut wird. So kann in der Spalte angegeben werden, ob 
eine Riickmeldung an die PLU erfolgen soli, wenn die Verbindung 
auf- oder abgebaut wird, sowie welcher Art die Riickmeldung 
ist. Die Riickmeldung erfolgt gemaB DE 196 51 075.9-53 Figur 
15, wobei statt des Latches 1504 ein Tor eingesenzt ist, das 
je nach Einstellung entweder beim Verbindungsaufbau oder - 
abbau durchschaltet und die Riickmeldung an die Transistoren 
(1502), die als Open-Kollektor-Treiber geschaltet sind 
ansteuern. 
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Kurzbeschreibung der Diagramme 

Fig. 1 Zeigt einen zweisimensionalen Baustein mit Zellarray 
und Knoten. 

Fig. 2 Zeigt einen Ausschnitt aus Fig. 1. 

Fig. 3 Zeigt mehrere bestehende Busverbindungen und den Aufbau 
neuer Verbindungen. 

Fig. 4 Zeigt den Aufbau neuer Busverbindungen. 

Fig. 5 Zeigt den nachsten Schritt des Verbindungsaufbaus . 

Fig. 6 Zeigt die Kollistion zweier Busse. 

Fig. 7 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 

Fig. 8 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 

Fig. 9 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 

Fig. 10 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 
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Fig. 11 Zeigt den Neuaufbau der abgebauten verbindung nach 
einer gewissen Zeitspanne. 

Fig. 12 Zeigt die Fortsetzung von Fig. 6, wenn der Knoten mehr 
als eine Sammelschiene besitzt und somit keine Kollision 
stattf indet . 

Fig. 13 Zeigt die Verbindung der Bussegraente mit den 
Sammeischienen eines Knotens. 

Fig. 14 Zeigt den Datentransf er eines Verbindungsaufbaus . Die 
Unterfiguren zeigen den Zustand der Verbindung jeweils im 
Abstanden von einem Buszyklus. 

Fig. 15 Zeigt den Datentransf er eines Verbindungsabbaus . Die 

Unterfiguren zeigen den Zustand der Verbindung jeweils im 

Abstanden von einem Buszyklus. 

Fig. 16 zeigt die Steuereinheit eines Knotens. 

Fig. 17 Zeigt das Broadcasting an mehrere Datenempf anger . 

Fig. 18 zeigt eine gegenuber Figur 16 verbesserte 

Steuereinheit eines Knoten mit Kollisionsdetektoren . 

Fig. 19 zeigt eine gegenuber Fig. 16 verbesserte 

Routingtabelle mit Ansteuerung der Fig. 18. 

Fig. 20 zeigt die zu Fig. 18/19 passenden Sammeischienen. 

Fig. 21 zeigt ein gegenuber Fig. 17 verbessertes Broadcasting 

an mehrere Knoten. 

Fig. 22 zeigt die Ablauf steuerung der Fig. 18-21. 
Fig. 23 zeigt einen Busknoten gemMii dem erweiterten 
Routingverf ahren . 

Fig. 24 zeigt eine optimierte Variante von Fig. 23. 
Fig. 25 zeigt ein Datenregister mit Synchronisationseinheit . 
Fig. 26 zeigt einen Kollisionsdetektor nach dem erweiterten 
Routingverf ahren . 
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Fig. 27 zeigt die Steuereinheit fur Fig. 23-26. 

Fig. 28 zeigt einen durchsatzsteigernden, kaskadierbaren 

Zusatz zu Fig. 27. 

Fig. 29 zeigt die Steuerregister fur Fig. 27 (2705). 

Fig. 30 zeigt einen Busaufbau liber relative Raumkoordinaten 

gemafl dem erweiterten Routingverf ahren. 

Fig. 31 zeigt einen Busaufbau iiber absolute Raumkoordinaten 

gemaii dem erweiterten Routingverf ahren. 

Fig. 32 zeigt die Verwaltung der Raumkoordinaten. 

Fig. 33 zeigt einen segmentierten Busaufbau. 

Detailbeschreibung der Diagramme 

Figur 1 zeigt einen Baustein der Gattungen FPGA, DPGA, DFP (DE 
44 16 881 Al) . Der Baustein ist zweidimensional symmetrisch 
aus konfigurierbaren Zellen (0101) aufgebaut, dabei kann 0101 

auch eine Mehrzahl von auch unterschiedlichen 

konfigurierbaren Zellen, die zu einer Gruppe zusammengef alit 
und untereinander vernetzt sind, reprasentieren. Zwischen den 
Zellen befinden sich die Knoten des Bussystemes (0102) . Dabei 
sind mehrere Knoten gekennzeichnet , die im folgenden 
Ausfiihrungsbeispiel mehrere Verbindugnen aufbauen werden. Der 
Datensender A (0103) wird im Folgenden eine Verbindung zum 
Datenempf anger A (0104) aufbauen, sowie der Datensender B 
(0106) mit dem Datenempf anger B (0105) . Eine ausschnittsweise 
Vergrofierung (0107) ist in Fig. 2 dargestellt. 
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Figur 2 zeigt einen Ausschnitt aus einem Baustein 
beschriebener Gattung. Die konf igurierbare (n) Zelle(n) aus 
Fig. 1 (0101) sind in 0201 dargestellt . Ein Bundel (0203) aus 
einer Vielzahl von Leitungen (die Anzahl ist beliebig und 
nicht exakt dargestellt) verbindet 0201 mit einem Knoten 0202. 
Die Knoten (0202) sind uber die Bussegmente (0205) miteinander 
verbunden. Ebenfalls haben die Knoten uber die Bussegmente 
0206, deren Ausgestaltung dieselbe wie die der Bussegmente 
0205 ist, Anschlufi an die sich aulierhalb der VergroJierung 
befindenden Knoten. Uber das optionale Leitungsbundel (0204) 
wird verdeutlicht, daft die konf igurierbare (n) Zelle(n) auch 
uber mehrere unterschiedliche Leitungsbundel an eine Mehrzahl 
von Knoten (0202) angeschlossen sein kann/konnen. 

Figur 3 zeigt den Baustein zur Laufzeit. 
Es existieren mehrere Verbindungen: 

- zwischen den Knoten Z (0301) 

- zwischen den Knoten Y (0306) 

Der Datensender A (0302) versucht eine Verbindung (0303) zum 
Datenempfanger A (0307) aufzubauen. Die Verbindung wird jedoch 
zuruckgewiesen (REJECT), da sie beim Knoten Z (0308) biockiert 
ist. Gleichzeitig baut der Datensender B (0304) ein Bussegment 
(0305) zu seinem Empfanger auf . Dieser Versuch gelingt, da der 
angesprochene Knoten und das benotigte Bussegment nicht 
biockiert ist. 

Figur 4 zeigt den nachsten Buszyklus. Die Verbindungen Y und Z 
sind zwischenzeitlich abgebaut. Der Datensender A (0401) kann 
nun das Bussegment (0403) aufbauen, da der Knoten (0402) nicht 



26 



WO 98/35294 



PCT/DE98/00456 



mehr blockiert ist Gleichzeitig baut der Datensender B (0404) 
das bereits bestehende Bussegment (0405) liber den Knoten 
(0406) hinaus aus => Das neue Bussegment (0407) wird 
aufgebaut . 

Figur 5: Der in Fig. 3 begonnene und uber Fig. 4 fortgesetzte 
Busaufbau setzt sich Equivalent zu Fig. 4 fort. 

Figur 6: Der Verbindungsaufbau des Bussegmentes 0602 des 
Datensenders B schlagt fehl. Der Knoten 0601 ist besetzt und 
liefert ein REJECT-Signal, das das Fehlschlagen des 
Verbindungsaufbaus signalisiert und den Abbruch der Verbindung 
bewirkt, an den Knoten 0603. 

Figur 7 zeigt den kompletten Verbindungsaufbau zwischen dem 
Datensender A (0701) und dem Datenempf anger A (0702). Die 
Verbindung des Datensenders B wird weiter abgebaut. Der Knoten 
0703 liefert uber das Bussegment (0704) das REJECT-Signal an 
den Knoten 0705. Daraufhin wird das Segment 0704 abgebaut. 

Figur 8: Der Datentransf er zwischen dem Datensender A und dem 
Datenempf anger A beginnt. Die Verbindung des Datensenders B 
wird weiter abgebaut. Der Knoten 0801 liefert uber das 
Bussegment (0802) das REJECT-Signal an den Knoten 0803. 
Daraufhin wird das Segment 0802 abgebaut. 

Figur 9: Der Datentransf er zwischen dem Datensender A und dem 
Datenempf anger A setzt sich fort. Das letzte Segment des 
Datensenders B wird abgebaut. Der Knoten 0901 liefert uber das 



27 



WO 98/35294 



PCT7DE98/00456 



Bussegment (0902) das REJECT-Signal an den Knoten 0903. 
Daraufhin wird das Segment 0902 abgebaut. 

Figur 10: Der Datentransf er zwischen dem Datensender A und dem 
Datenempfanger A setzt sich fort. Der Datensender B (1001) 
wartet eine Zeitspanne ab, bis er erneut versucht eine 
Verbindung zu seinem Datenempfanger aufzubauen. 

Figur 11 zeigt den Zustand mehrere Buszyklen spater: Der 
Datentransf er zwischen dem Datensender A und dem 
Datenempfanger A findet immer noch statt. Der Datensender B 
(1101) startet einen neuen Versuch die verbindung zu seinem 
Datenempfanger aufzubauen. Er baut ein Bussegment (1102) zum 
Knoten (1103) auf. Sofern in den nachsten Buszyklen die 
Verbindung des Datensenders A zu seinem Datenempfanger A 
abgebaut ist, gelingt der Verbindungsaufbau des Datensenders B 
(1101) , ansonsten schlagt sie wie in Fig. 6 beschrieben erneut 
fehl. 

Figur 12 zeigt die Fortsetzung der Fig. 6, wenn der Knoten 
1202 in der Lage ist mehr als eine Verbindung aufzubauen, das 
heifit, der Knoten besitzt mehrere interne Sammeischienen . 
Dadurch kann die Verbindung des Datensenders A uber die erste 
Sammelschiene abgewickelt werden und die Verbidnung des 
Datensenders B uber die Zweite. Der Knoten 1202 baut das 
Bussegment 1203 zu dem Datenempfanger B (1201) auf. 

Figur 13 stellt eine knoteninterne Vernetzungsstruktur dar. Es 
existieren vier knoteninterne Sammeischienen 1301, 1302, 1303, 
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1304. Uber je eine Gruppe von Toren (1308, 1309, 1310, 1311) 
werden die Sammelschienen auf die Bussegmente Westen (1318), 
Norden (1316), Osten (1319), Stiden (1317) geschaltet. Uber die 
Tore 1307 werden die Sammelschienen mit den O-REGl/2 (vgl. DE 
196 51 075.9-53) verbunden (1314, 1315). Uber die Tore 1306 
wird das R-REG (vgl. DE 196 51 075.9-53) auf die 
Sammelschienen geschaltet. Dabei kann das niederwertige und 
hoherwertige R-REG (1312, 1313) jeweils getrennt verschaltet 
werden. Die Tore werden uber den Bus 1320 angesteuert. Dabei 
wird das benotigte Torsystem (Westen, Norden, Osten, Suden) , 
sowie die interne Sammeischiene angegeben. Durch VerUNDung 
(1325, 1326, 1327, 1328) der Richtungsangabe mit der Angabe 
der selektierten Sammeischiene wird das erf orderliche Tor 
(1321, 1322, 1323, 1324) ausgewahlt. 

Figur 14a zeigt den Aufbau einer Verbindung, dabei ubermittelt 
der Datensender (1401) dem Knoten des Datensenders (1402) das 
erste Datenpaket. 

Figur 14b Der Knoten selektiert dabei aus der Routingtabelle 

den zu rRDY rRDY ist ein Statussignal, das anzeigt, dali 

Daten am Datensender bereitstehen (vgl. DE 196 51 075.9-53) 
- gehorenden Eintrag. Anhand diesem Eintrag wird das nachste 
Bussegment aufgebaut und die Adresse der Routingtabelle des 
nachsten Knotens ubertragen. 

Figur 14c Der letzte Knoten (1403), der Datenempf angerknoten, 
erhalt die Adresse fur den Eintrag innerhalb seiner 
Routingtabelle. Der Eintrag zeigt auf keinen weiteren Knoten, 
sonderen auf eine Zelle. Daher aktiviert der Knoten sofort 
seine Tore zur selektierten Zelle. 
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Figur 14d Die Daten gelangen durch das aktivierte Tor von 1403 
direkt zur Empf angerzelle 1404. 

Figur 14e Die Zelle sendet das oACK-Signal (vgl. DE 196 51 
075.9-53) als Quittierung fur die erhaltenen Daten zuriick. Im 
nachsten Buszyklus (vgl. Fig. 14e) wird der Datensender 
daraufhin das nachste Datenpaket absenden. 

Figur 14e-g Der normale Datenaustausch zwischen den Zellen 
lauft ab. 

Figur 15a Es existiert eine Datenverbindung vom Datensender 
(1501) zum Datenempf anger (1503) uber mehrere Knoten. 
Figur 15b Der Datensender (1501) hat seine Datenubertragung 
beendet und sendet ein DISCONNECT-Signal zum ersten Knoten. 
Figur 15c Das erste Bussegment ist abgebaut und der Knoten 
reicht das DISCONNECT-Signal weiter. 
Figur 15d Der Verbindungsabbau geht weiter. 

Figur 15d Der letzte Knoten erhalt das DISCONNECT. Daraufhin 
baut der letzte Knoten gleichzeitig die Verbindung zum 
Vorgangerknoten und zum Datenempf anger ab. 
Figur 15e Das letzte Bussegment und die Verbindung zum 
Datenempf anger ist abgebaut. 

Figur 15f zeigt das ein Abbauverf ahren, bei dem die 
DISCONNECT-Leitung durch alle Knoten durchgeschleif t ist. 
Dabei wird das DISCONNECT in einem Taktzyklus propagiert; alle 
Segmente werden gleichzeitig abgerissen. 
Figur 15g entspricht Figur 15e. 

Figur 16 Zeigt die Steuerung eines Knotens. Die Anf orderungen 
(1601) zum Aufbau einer Verbindung gelangen uber den 
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Prioritatsdekoder (1602) an die Routingtabelle (1603). Der 
Prioritatsdekoder wahlt die Anforderung mit der hochsten 
Prioritat aus, wobei eine soeben f ehlgeschlagene Anforderung 
die niederste Prioritat zugewiesen bekommt. Die 
Prioritatslogik erhalt Ihre Anf orderungen uber Statussignale 
(z.B. der der konf igurierbaren Zellen (vgl. DE 196 51 075.9- 
53) rRDY, oACK) oder uber die Bussegmente 1316, 1317, 1318, 
1319. Liegen Daten an den Bussegmenten an, ohne daft das Tor 
des Bussegmentes aktiviert ist, werden die Daten von der 
Prioritatslogik als Adresse der Routingtabelle interpretiert 
und als Anforderung betrachtet. Liegen Statussignale an der 
Prioritatslogik an (rRDY, oACK) , werden diese in Adressen fur 
die Routingtabelle ubertragen. Die Adressen der Routingtabelle 
selektieren einen Eintrag. Die Daten des Eintrages (1604) 
werden an eine Einheit aus UND-Gattern (1605) weitergeleitet . 
Dabei wird die Binarzahl der Busauswahl (BUS 1..0) uber einen 
2:4 Dekoder (1606) in Selektsignale ubertragen. Die UND- 
Gatter-Einheit verUNDet dabei jedes Signal mit demselben in 
einem Latch (1607) gespeicherten Signal. Das heiftt daft das 
Signal GAT El der Routingtabelle mit dem Signal GATE1 des 
Latches verUNDet wird, das Signal GATE 2 der Routingtabelle mit 
dem Signal GATE 2 des Latches und so weiter. Dabei 
reprasentieren die Signale des Latches den Zustand der 
momentan aktuellen Vernetzungsstruktur, d.h. die benutzten 
Tore und die benutzten Sammelschienen sind in das Latch 
eingetragen. Ergibt eine VerUNDung der Verbindungsanf orderung 
mit dem aktuellen Zustand einen wahren Pegel, bedeutet dies, 
daft die neue Verbindungsanf orderung Ressourcen benotigt, die 
momentan benutzt sind. Ober ein ODER-Gatter (1608) werden alle 



31 



WO 98/35294 



PC1YDE98/00456 



UND-Gatter miteinander verknupft. Ergibt sich am Ausgang des 
ODER-Gatters ein wahrer Pegel, wird die Verbindungsanf orderung 
zuruckgewiesen (REJECT) (1609), da die benotigten Ressourcen 
belegt sind. Aus dem REJECT-Signal wird tiber einen Inverter 
(1610) das ACCEPT-Signal (1611) generiert. Die Signale 
werden an eine Zustandsmaschine (1612), die nach dem Stand der 
Technik implementiert sein kann, weitergeleitet . Diese steuert 
danach die Annahme der Verbindung oder die Zuruckweisung. Wird 
die Verbindungsanf orderung zuruckgewiesen, meldet (1613) die 
Zustandsmaschine den REJECT an den Prioritatsdekoder und die 
Anf orderung erhalt niederste Prioritat. Bei einer Annahme der 
Anforderung, werden die neuen Zustandssignale mit den 
aktuellen Zustandssignalen nach dem Latch verODERt (1614) — 
dabei ist die ODER-Einheit ebeso aufgebaut wie die 

beschriebene UND-Einheit (1605) und in das Latch (1607) 

zuruckgeschrieben. Uber 1623 steuert die Zustandsmaschine, ob 
die ODER-Einheit (1614) oder die Maske (1616) aktiv ist. Das 
Latch wird uber 1622 von der Zustandsmaschine getriggert. Uber 
den Bus 1615 gelangt die neue Einstellung an die Tore, 

Der Abbau einer Busverbindung lauft auf ahnliche Weise. 
Allerdings findet mufi bei einer Oberprufung der Ressourcen das 
Signal REJECT auftreten, da die Busverbindung, die abgenbaut 
werden soil, existieren mufi. Aufgrund des REJECTS aktiviert 
die Zustandsmaschine 1612 anstatt der ODER-Einheit 1614 die 
Maske 1616. Die Verbindungsdaten der abzubauenden Verbindung 
werden aus dem aktuellen Vernetzungszustand ausmaskiert und in 
das Latch 1607 zuruckgeschrieben. Vor dem Zuruckschreiben der 
neuen verbindungsdaten sendet die Zustandsmaschine das 
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DISCONNECT-Signal zum Abbau der Verbindung an den nachsten 
Knoten. 

Ober die Tore 1617, 1618, 1619, 1620 kann die Steuerung direkt 
auf die Sammelschienen 1301, 1302, 1303, 1304 zugreifen. Damit 
kann die Zustandsmaschine sowohl Steuersignale (DISCONNECT) 
auf die Sammelschiene ubertragen, als auch Steuersignale von 
der Sammelschiene erhalten (REJECT, ACCEPT) und auf diese 
reagieren. Ebenfalls dienen diese Tore urn den Eintrag Position 
in Zieltabelle (uber 1621) auf die Sammelschiene zu 
ubertragen. 

Uber 1624 kann die Ladelogik (PLU) auf die Routingtabelle 
zugreifen. 

Figur 17 Zeigt ein Broadcasting eines Datensenders (1701) an 
mehrere Datenempf anger (1702) uber eine Vielzahl von Knoten 
(1707), auf die nicht nahers eingegangen wird. Der Bus ist zur 
Verdeutlichung aufgetrennt dargestellt, namlich in die 
Quittierungsleitung (ACK) (1703) und den restlichen Bus 
(1704). ACK wird dabei negiert und an den wiederum 
invertierenden Open-Kollektor-Bustreiber geliefert. ACK wird 
uber einen PullUp-Widerstand 1705 auf H gezogen. Dabei ist die 
Schaltung so aufgebaut, daiJ folgende Falle eintreten: 

- Wird der entsprechende Bus nicht angesteuert, liegt an der 
Basis des Transistors (1706) L an. Dadurch belastet er den Bus 
nicht . 

- Wird der entsprechende Bus angesteuert, und das Signal nicht 
quittiert, liegt an der Basis des Transistors (1706) H an. Das 
bedeutet, daft der Bus auf L gezogen wird. Wird ein Ergebnis 
per Broadcasting an mehrere Datenempf anger verteilt, so Ziehen 
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alle Knoten, die die Ergebnisdaten noch nicht quittiert haben 
und Warte-Zyklen benotigen den Bus auf L. 
- Wird der entsprechende Bus angesteuert, und das Signal 
quittiert, liegt an der Basis des Transistors (1706) L an. Das 
bedeutet, dafi der Bus nicht belastet wird. Wird ein Ergebnis 
per Broadcasting an mehrere Datenempf anger verteilt, so 
belasten alle Knoten, die die Ergebnisdaten quittiert haben 
und keine Warte-Zyklen benotigen, den Bus nicht. 
Da der Bus in seinem Grundzustand den H-Pegel, also die 
Quittierung, einnimmt, ubersteuert die Nichtquittierung gemaft 
Fall 2 die Quitrierung, indem sie den Bus auf L zieht. Dabei 
geht der Bus erst dann in den H-Pegel, also in den 
Quittierungszustand, wenn alle an der Verbindung beteiligten 
Knoten quittieren. Es ist somit eine Wired-AND-Schaltung 
realisiert . 



Im Folgenden ist ein Implemetierungbeispiel fur einen Knoten 
dargestellt, der den folgenden Busaufbau besitzt: 



Data 


Datensignale 


ACK 


Daten- und Auf bau-Handshake 


RDY 


Datenhandshake (Daten liegen an) 


ESTABLISH 


Aufbauhandshake (das Segment wird aufgebaut) 


DISCONNECT 


Aufforderung zum Busabbau (durch einen 
Timeout) 


RECONFIG 


Aufforderung zum Busabbau (durch 
Umkonf iguration der beteiligten 
konf igurierbaren Zellen) 
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Figur 18 zeigt die Ansteuerung von der Sammelschienen aus 
Figur 13. Im Gegensatz zu der bisher beschriebenen Losung, die 
Sammelschiene in den Routingtabellen vorzugeben, ist die Logik 
in der Lage eine freie Sammelschiene selbst f estzustellen und 
zu allokieren. 

Je eine Ansteuereinheit 1801 ist einer Sammelschiene 
zugeordnet. Eine Ansteuereinheit besteht aus einem Tor 
(1801a) , urn wahrend des Verbindungsauf baus die 
Adressinformationen der Routingtabelle an die Sammelschiene 
angeschlossenen Knoten zu senden und einem Register (1801b), 
das die Ansteuerung der Sammelschiene ubernimmt. 1801 erhalt 
uber den Bus 1813 die Daten mittels einer in Figur 19 
beschriebenen Schaltung aus der Routingtabelle. Ober 1801b 
werden die Tore f reigeschaltet , die Zugriff auf die 
entsprechend zugeordnete Sammelschiene haben. Jedes Tor 
besitzt eine Freischaltesignal, dem ein Eintrag in 1801b 
zugeordnet ist. Wenn kein Eintrag gesetzt ist, ist die 
zugeordnetet Sammelschiene unbelegt und kann frei einer 
Zugriff sanforderung zugeteilt werden. Die Oberprufung wird 
durch eine ODER-Funktion (1802) uber alle Freischaltesignale 
an die Tore realisiert. Die Ergebnisse der 1802 aller 
Sammelschienen werden einem Arbiter (1803) zugefuhrt, der eine 
der freien Sammelschienen auswahlt und liber einen Adressbus 
(1804) deren 1801 anspricht. Ist keine Sammelschiene frei, 
signaiisiert 1803 dies uber 1805 der steuernden Statemachine . 
Je ein Eintrag in 1801b kennzeichnet ein der Sammelschiene 
zugeordnetes Tor. Die Position ist in jedem 1801b dieselbe. 
Das bedeutet ab Position p eines 1801b befindet sich immer das 
Freischaltesignal fur das Tor p, an Position p+1 das 
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Freischaltesignal fur Tor p+1 und an Position q das 
Freischaltesignal fur Tor q. Wird iiber die Freischaltesignale 
von je einem Tor p eine ODER-Funktion (1806) ausgefuhrt, gibt 
das Resultat an, ob Tor p frei ist oder nicht. Fur jedes Tor 
existiert eine derartige Oberpruf ungsf unktion (1807 = Tor p+1, 
1808, 1809 = Tor q) . Ober eine Maske 1810 werden alle Tore, 
die fur den aktuellen Verbindungsaufbau irrelevant sind 
ausmaskiert , d.h. irrelevante Tore werden durch die Maske als 
nicht f reigeschaltet weitergeleitet . Ober eine ODER-Funktion 
(1811) wird festgestellt ob eines der Tore f reigeschaltet ist. 
Da alle irrelevanten Tore mit "nicht f reigeschaltet " markiert 
sind, wird nur der Zustand des fur den aktuellen 
Verbindungsaufbau notwendigen Tores an die State-Machine 
weitergeleitet (1812) . Ist das gewunschte Tor f reigeschaltet , 
kann es bei dem aktuellen Verbindungsaufbau nicht genutzt 
werden, da ansonsten eine Kollision eintreten wiirde. Der 
Verbindungsaufbau wird unterbrochen und entweder 
zuruckgewiesen oder zu einem spateren Zeitpunkt erneut 
versucht . 

In Figur 19 ist der Arbiter zur Auswahl des aktiven Busses und 
die Routingtabelle dargestellt. Jeder an einen Knoten 
angeschlossene Bus (2004, 2005, 2006) sendet seine 
Zugrif f sanf orderung uber ein Signal (1901) an einen Arbiter 
(1902), der eine der Zugrif f sanf orderungen auswahlt. Ober 
einen Dekoder (1903) wird der Multiplexer (1904) so 
angesteuert, daii entweder die Nummer des ausgewahlten 
Zugriffes (bei direkten Zugriff durch eine konf igurierbare 
Zelle) (1905) oder die Lookup-Addresse des ausgewahlten 
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Zugriffes an die Routingtabelle 1906 ubertragen wird. 1906 
gibt die, dem Wert von 1905 zugeordneten, Daten aus. Die 
Lookup-Address e far den nachsten Knotens wird direkt liber 1813 
an 1801a ubertragen. Die Adresse des nachsten Knotens wird 
dezimal auskodiert (1907) uber einen Mischer (1908), der flir 
gewohnlich aus ODER-Gattern ausgestaltet ist, mittels des 
Busses 1813 an 1801b ubertragen. 1st der Bus zum nachsten 
Knoten aufgebaut, wird die Freischaltung des Tores zum 
vorhergehenden Knoten ermoglicht , indem die uber den 
Dezimaldekoder 1909 auskodierte Adresse des vorhergehenden 
Knotens im Mischer 1908 auf den Bus 1813 zugeschaltet wird und 
zu 1801b ubertragen wird. 

Figur 20 zeigt die Sammelschienen (2001, 2002, 2003) zur 
Aufschaltung der anliegenden Busse (2004, 2005, 2006) . Ober 
die Multiplexer/Demultiplexer (2007) werden die Busse gemali 
der Ansteuerung durch 1801b auf die Sammelschienen geschaltet, 
dabei werden einem Multiplexer p die Ausgangssignale p aller 
1801b zugefuhrt, einem Multiplexer p+1 die Ausgangssignale p+1 
aller 1801b, etc. Die einzelnen Signale reprasentieren 
anlieger.de Sammelschienen, da jede Sammelschienensteuerung 
genau eines (p) aus einer Vielzahl von Signalen (p x , p x +i, - . , q x ) 
ansteuert. 1st ein zu einer Sammelschienensteuerung gehorendes 
Signal gesetzt, wird die entsprechende Sammelschiene durch 
einen 2007 auf geschaltet • 

Die Timeout-Generatoren (2008) steuern den Abbau des 
jeweiligen Segment es und den auf geschalteten Bussen. Die 
Timeout-Generatoren werden direkt von der Routingtabelle 
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(1906) konfiguriert . Die Verbindung ist der Einfachheit halber 
in den Zeichnungen nicht dargestellt. 

Die einer jeweiligen S amine lschiene zugeordneten 1801a werden 
auf diese Sammelschiene auf geschaltet . 

In Figur 21 wird ein Bussegment (2105) uber einen Knoten 
(2101) an mehrere Knoten (2102, 2103, 2104) gebroadcastet . Das 
RDY-Handshake wird, ebenso wie die Daten direkt an jeden 
Empf anger gesendet. Uber die Masken (2105, 2106) werden die 
rucklaufigen ACK-Handshakes auf das ODER-Gatter (2107) und das 
UND-Gatter (2108) geschaltet. Uber die Masken wird dabei 
ausgewahlt, welches ACK signifikant ist, und ob ein ACK durch 
eine boolsche UND-Funktion oder eine ODER-Funktion 
weitergeleitet wird. Beide Funktionen werden uber ein ODER- 
Gatter (2109) zusammengefaflt , Ist ein ACK irrelevant, so gibt 
die Maske 2105 eine logische 0 (L-Pegel) weiter, wahrend die 
Maske 2106 eine logische 1 (H-Pegel) weitergibt. Die Masken 
2105 und 2106 werden getrennt von der Routingtabelle gesetzt. 
Die Verbindung ist der Einfachheit halber in den Zeichnungen 
nicht dargestellt. 

In Figur 22 ist die Statemachine der beschriebenen Schaltung 
dargestellt . 

Der Grundzustand ist "IDLE", den die Statemachine erst 
verlalit, wenn ein "request" (Zugriff) auftrat UND eine 
Sammelschiene UND das selektierte Tor frei sind. Dabei 
quittiert die Statemachine der vorhergehenden Statemachine den 
Busaufbau durch senden eines ACK-Handshakes. Die Statemachine 
geht in den SEND-Zustand, wahrend dessen die Daten der 
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Routingtabelle (uber 1801a) an die nachf olgende Routingtabelle 
gesendet werden. Diesen Zustand verlalit die Statemachine erst 
beim Eintreffen eines ACK-Handshakes der nachf olgenden 
Routingtabelle ODER beim Eintreffen eines "disconnect"- 
Signales auf dem Bus, z.B. durch einen Timeout. Bei einem 
"disconnect" geht die Statemachine in den DISCONNECT-Zustand, 
urn den Bus abzubauen (dieser Zustand ist nicht notwendig, in 
der Implementierung wird direkt nach IDLE zuruckgesprungen, 
dient aber in diesem Beispiel der besseren Obersicht) . Bei 
Eintreffen eines ACK-Handshakes wird in den IDLE-Zustand 
zuruckgesprungen, dabei wird uber 1909/1908 das Tor der 
vorhergehenden Routingtabelle in 1801b f reigeschaltet . 
Urn die Leistung der Routingtabelle zu erhohen kann auf das 
warten auf ein ACK-Handshake wahrend des SEND-Zustandes 
verzichtet werden. Dazu mussen wahrend SEND die zu sendenden 
Zugriff sdaten an die nachfolgende Routingtabelle in 1801a 
gespeichert werden, d.h. 1801a ist ein Register; gleichzeitig 
mufi wahrend SEND die Information uber die vorhergehende 
Routingtabelle in ein zusatzliches 1801b geschrieben werden. 
Das Eintreffen des ACK-Handshakes der nachf olgenden 
Routingtabelle, bewirkt in unabhangig aufgebauter Logik das 
Abschalten von 1801a und das Umschalten von dem erste 1801b 
auf das Zweite, indem die Verschaltung des Tors der 
vorhergehenden Routingtabelle gespeichert ist. 

Die folgenden Figuren beschreiben ein Implementationsbeispiel 
nach dem "erweiterten" Routingverf ahren, der Bus sieht wie 
folgt aus: 
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Data 


Datensignale 


ACK 


Daten- und Aufbau-Handshake 


RDY 


Datenhandshake (Daten liegen an) 


DISCONNECT 


Aufforderung zum Busabbau (durch einen Timeout) 


RECONFIG 


Aufforderung zum Busabbau (durch Umkonf iguration 
der beteiligten konf igurierbaren Zellen) 


X/Y 


X/Y-Raumkoordinaten 


LUT 


Lookup-Adresse fur die Routingtabelle 


ADR-MODE 


Gibt an ob die X/Y-Raumkoodinaten oder die 
Lookup-Adresse verwendet werden soil. 1st X=0 
UND Y=0 wird automatisch die Lookup-Adresse 
verwendet. 



Figur 23 zeigt einen Knoten mit den Schaltelementen 
1,2,3,4,5,6, sowie den Bussen Bl, B2, B3, B4. 

Figur 23a) . Die Zeichnung ist zur besseren Darstellbarkeit als 
ein Ein-Leitungssystem ausgestaltet . Tatsachlich handelt es 
sich urn ein Bussystem. Dazu sind alle Figuren urn die Menge der 
Busleitungen zu duplizieren. Die Schaltelemente sind im 
einfachsten Fall aus einem Transistor (2301) aufgebaut. 
Figur 23b) Urn Daten zwischenspeichern zu konnen, wird das 
Schaltelement urn ein Register (2302) erweitert. Ober die 
Transistoren Tl, T2, T3, T4 werden die bidirektionalen Busse 
Bn und Bm so auf das Register geschaltet, daJJ entweder der 
Obergang Bm -> Bn oder der Ubergang Bn -> Bm gespeichert wird. 
Ober T5 wird alternativ ein bidirektionaler ungespeicherter 
Datentransfer ermoglicht. Ober die Steuersignale SI, S2, S3, 
S4 wird der Modus des Schaltelementes wie f olgt eingestellt : 
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SI 


Bm -> Bn (unidirektional, gespeichert) 


S2 


Bin <-> Bn (bidirektional, nicht gespeichert) 


S3 


Bn <-> Bm (bidirektional, nicht gespeichert) 


S4 


Bn -> Bm (unidirektional, gespeichert) 



Figur 23c) Urn eine bessere Signalqualitat zu erhalten, werden 
Eingangsschmittrigger und Ausgangstreiber (2303) eingesetzt. 
Die Treiber (2303) sind so ausgestaltet , dali uber ein 
Steuersignal pegelabhangig- entweder der Ausgangs oder der 
Eingangstreiber f reigeschaltet wird. Die Bidirektionalitat 
geht verioren, es sind ausschiefilich unidirektionale 
Schaltvorgange realisierbar : 

S4 wird der Modus des Schalteleraentes wie folgt eingestellt: 



SI 


Bm -> Bn (unidirektional, gespeichert) 


S2 


Bm -> Bn (unidirektional, nicht gespeichert) 


S3 


Bn -> Bm (unidirektional, nicht gespeichert) 


S4 


Bn -> Bm (unidirektional, gespeichert) 



Figur 23d) Die Ein- und Ausgange verlaufen auf 
unterschiedlichen Leitungen (Bmi, Brno, Bni, Bno) zur besseren 
Implementierbarkeit in Chips, Die Treiber (2304) sind 
unidirektional ausgestaltet. Die Ansteuerung der Treiber kann 
entfallen. 
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SI 


Bmi -> Bno (unidirektional, gespeichert) 


S2 


Bmi -> Bno (unidirektional, nicht gespeichert) 


S3 


Bni -> Brno (unidirektional, nicht gespeichert) 


S4 


Bni -> Brno (unidirektional, gespeichert) 



Figur 24 zeigt einen Knoten ahnlich dem Knoten aus Figur 23. 
Der Vorteil des Knotens liegt in seiner besseren 
Implementierbarkeit und Verwaltung der Register. Die Zeichnung 
ist zur besseren Darstellbarkeit als ein Ein-Leitungssystem 
ausgestaltet . Tatsachlich handelt es sich urn ein Bussystem. 
Dazu sind alle Figuren urn die Menge der Busleitungen zu 
duplizieren. Die Register und Treiber (A, B, C, D) sind den 
Schaltelementen (1, 2, 3, 4, 5, 6) vorgeordnet. Die 
Schaltelemente reduzieren sich auf die in Figur 24a gezeigte 
Kreuzschaltung. Mittels der Transistoren T6, T7 werden die 
Eingange (Imi, Ini) jeweils selektiv mittels der 
Steuerleitungen S5, S6 auf die Ausgange (lino, Ino) geschaltet. 
Die Figuren 24b-d zeigen verschiedene Ausgestaltungsarten der 
Register und Treiber (A, B, C, D) . 

In Figur 24b wird ein bidirektionaler Bus uber T8 entweder als 
Eingang zum Regsiter 2401 geschaltet, oder uber T9 aus Ausgang 
geschaltet, wobei der knoteninterne Bus Imo die Signalquelle 
darstellt. T8 und T9 werden liber die Steuerleitung S7 
angesteuert. Mittels des Transistorpaares T10/T11, das liber S8 
angesteuert wird, kann ein Register-Bypass geschaltet werden 
urn den quasi-permanenten Modus zu ermoglichen . Der Ausgang des 
Registers geht auf den knoteninternen Bus Imi. Die Vernetzung 
der Imi und Imo erfolgt uber die Schaltelemente aus Figur 24a. 
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In Figur 24c wir anstatt des Transistorpaares T8/T9 eine 
Treiberstufe (2402) zur Verbesserung der Signalqualitat zum 
Bus geschaltet. 

In Figur 24d ist der externe Bus zur besseren 
Implementierbarkeit in Chips unidirektional ausgestaltet . Die 
Treiber 2403 sind unidirektional, das Steuersignal S7 
entfallt. 

Figur 25 schlagt eine m5gliche Synchronisationsschaltung fur 
Fig. 24 vor. Die Register 2401 zur Datenspeicherung sind in 

2501 dargestellt. Das Register 2502 dient der Speicherung 
eines RDY-Handshakesignales, also der Information, dafi sich 
gultige Datenen auf dem Bus, bzw. in 2501 befindet. Befindet 
sich keine gultigen Daten in 2501, ist der Ausgang Q von 2502 
logisch 0. Treffen gultige Daten ein (RDY ist aktiv und 
logisch 1), wird uber das UND-Gatter 2503 ein 
Freischaltesignal (EN) fur die Register 2501 und 2502 
generiert, die Daten und das RDY werden rait der steigenden 
Taktflanke gespeichert. Der Eingang von 2503 fur Q (von 2502) 
ist invertierend! Treffen erneut Daten ein, ist der Ausgang 
(Q) von 2502 logisch 1. Das UND-Gatter liefert eine logische 0 
und die Register werden uber EN nicht f reigeschaltet . Werden 
die Daten uber den Bus weitergeleitet, wird das 
Aktivierungssignal des Ausgangstreibers (OE) als Clear fur 

2502 verwendet; Q von 2502 wird logisch 0 und neue Daten 
konnen mit dem nachsten Taktzyklus gespeichert werden. Die 
Leitung Din und Dout ist fett eingezeichnet , da es sich hier 
um ein Bussystem handelt. Ebenso ist 2501 fett gezeichnet, da 
das Register der Breite des Busses entspricht. 
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Es ist mbglich die Register als Latches aufzubauen und an die 
Pegei des Taktes (CLK) oder Handshakes (RDY) zu koppeln. Die 
Schaltung verhalt sich dadurch allerdings asynchron, was zu 
erheblichen Implementierungsproblemen fiihrt und dadurch einem 
nicht unerheblichem Zusatzaufwand unterliegt. 

Figur 26 zeigt die Teststrategie urn f estzustellen, ob eine 
Verbindung aufgebaut werden kann, d.h. das Netz frei ist. Die 
Statusinformationen der Schaltelemente 1,2,3,4,5,6, die 
Auskunft geben ob ein Schaltelement verschaltet oder frei ist, 
werden in einer Matrix 2603 angeordnet. Dabei bilden die 90°- 
Schalz:eiemente 3,4,5,6 die Ecken, die 180 —Schaltelemente 1 
und 2 die Mittelstucke und kommen doppelt vor. Urn ein 
Schaltelement kollisionsf rei zu benutzen muft die gesamte Kante 
in welcher sich das Schaltelement befindet frei sein. 
Beispielsweise ist es moglich 1+2, 6+4, 3+5 zu benutzen. 
Unmoglich dagegen ist beispielsweise 6+2, 6+1, 2+5, 2+4, 2+3, 
etc. 

Es muft also sichergestellt und getestet werden, daft jede Kante 
nur einmal belegt ist. Die Daten hierzu liefert ein Register 
2602, in dem die aktuelle Verschaltung des Knoten gespeichert 
ist tiber den Eingang r; sowie die Routingtabelle 2601, die die 
Daten des gewunschten neuen Busses liber den Eingang t an die 
Matrix weiterleitet . 

Die Testschaltung ist in Figur 26a dargestellt. Je eine Reihe 
(2605, 2606, 2607, 2608) wir uber ein ODER-Gatter (2609, 2610, 
2611, 2612) auf die Existenz einer Verschaltung uberpruft. 
Existiert ein verschaltetes Element in der Reihe, liefert das 
jeweilige ODER-Gatter eine logische 1, Das Ergebnis der 
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jeweiligen Reihe wird mittels jeweils eines UND-Gatters mit je 
einer sich in der Reihe befindenden, neu auf zubauenden 
Verschaltung verkntipft. 1st die Reihe bereits belegt UND eine 
weitere Verschaltung in der Reihe wird angefordert, liefert 
das jeweilige UND-Gatter eine logische 1. Die Ausgange aller 
UND-Gatter werden verODERt (2613) . Das Ergebnis des Tests 
liefert somit an 2604 eine logische 0, wenn die angeforderte 
Vernetzung gultig ist und eine logische 1, wenn eine Kollision 
vorliegt . 

Die Schaltung in Figur 26 ist lediglich in der Lage eine 
Anforderung pro Zeiteinheit zu verarbeiten. Eine zeitliche 
Optimierung ist in Figur 27 dargestellt. Uber 2701 gelangen 
die Zugrif f sanf orderungen von den Bussen an die Schaltung. Die 
Routingtabelle (2702) ist nicht aus einem ublichen Speicher, 
sondern aus einer Mehrzahl von einzelnen Registern (2711) 
aufgebaut. Dadurch konnen iiber die Multiplexer 27 03 die Daten 
samtlicher Zugrif f sanf orderungen gleichzeitig aus der 
Routingtabelle ausgelesen werden. Die Daten je einer 
Zugrif f sanf orderung werden an je eine Matrix (2704) gemafi 
Figur 26 geleitet, das die Vergleichsdaten aus dem Register 
mit der aktuellen Verschaltung der Knoten (2705) erhalt. Die 
Schaltung 2706 besteht aus einem ODER-Gatter, das das 
Vorhandensein einer gultigen Anfrage an die Matrix 2704 
feststellt. Das Ergebnis von 2704 wird uber einen Inverter mit 
dem Ausgang des ODER-Gatters verUNDet. Als Ergebnis wird bei 
einem bestehenden und gultigen Zugriff eine logische 1, 
ansonsten eine logische 0 geliefert. Jede Matrix besitzt je 
eine Schaltung 2706. Deren . Ergebnisse werden auf einen Arbiter 
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2707 geschaltet, der einen der gultigen Zugriffe auswahlt. Der. 
Multiplexer 2708 wird so geschaltet, daft die Daten des 
gliltigen Zugriffes auf den Mischer 2709 gelangen, der den 
. gultigen neuen Zugriff mit der bestehenden Verbindung 
verkniipft und an das Register 2705 zur Speicherung 
weiterleitet . 

Diese Schaltung ist in der Lage aus einem Menge von 4 
Zugriff en genau einen Gultigen auszuwahlen. Durch Anderung der 
Anzahl der Multiplexer (2703), Matrizen (2704), der Arbiter- 
und Multiplexerbreite (2707 , 2708) sowie der dazugehorenden 
Logiken, kann ein gultiger Zugriff aus einer beliebig 
einstellbaren Menge von Anfragen bearbeitet werden. 

Oftmals ist es erforderlich mehr als einen gultigen Zugriff 
aus einer Menge von Zugriff en auszuwahlen. Dazu dienen die 
Leitungen 2801, 2805, 2802 und 2810, die zu der 
Zusatzschaltung Figur 28 ftthren und eine gleichzeitige Auswahl 
von 2 Zugriffen ermoglichen. Wird 2810 verdrahtet, entfallt 
die Leitung 2710. Nach dem im Folgenden vorgestellten Prinzip 
kann durch Kaskadierung eine beliebige Menge von Zugriffen 
gleichzeitig ausgewahlt werden. 

Ober 2801 gelangt die Information, welcher Zugriff als 
"gultig" ausgewahlt wurde, an den Dekoder 2803. Die 
Information wird so auskodiert, daft uber die drei Multiplexer 
2804 nur die Zugriff sdaten der nicht ausgewahlten Zugriff an 
die Matrizen geleitet werden. Durch den Wegfall des bereits 
ausgewahlten Zugriffes verringert sich die Zahl der Matrizen 
urn eins. 
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Der Dekoder arbeitet wie in der Tabelle angegeben: 



Dekoder 
(2802) 


MUX1 


MUX2 


MUX3 


a 


b 


c 


d 


b 


a 


c 


d 


c 


a 


b 


d 


d 


a 


b 


c 



Die Tabelle gibt in der Spalte "Dekoder" den liber 2802 
selektierten "gtiltige" Bus an. In den Spalten MUX1-MUX3 wird 
angegeben, welchen Bus der jeweilige Multiplexer, abhangig von 
dem Wert 2802, selektiert. 

Die Matrizen (2811), die Logik (2806) und der Arbiter (2807) 
arbeiten wie aus Figur 27 bekannt. Ober den Multiplexer 2808 
werden die Daten des vom Arbiter ausgewahlten Zugriffes an dem 
Mischer 2809 geleitet. Der fugt ahnlich dem Mischer 2709 den 
Ausgangsdaten von 2709 die Daten des von der Logik von Figur 
28 ausgewahlten Zugriffes zu und leitet die generierten 
Zugriffsdaten liber 2810 an das Register 2705. Die 
Eingangsdaten des Multiplexers 2808 mussen aufgrund der 
Verschaltung in den Multiplexer 2804 von deren Ausgangen 
abgegriffen werden. 

Die Schaltung gemaG Fig. 28 ist in die Tiefe nach dem 
beschriebenen Prinzip weiter kaskadierbar, wobei sich die Zahl 
der Matrizen weiter urn jeweils eins pro Kaskade verringert. 

Figur 29 beschreibt ein Register gemall 2602 bzw. 2705. Die 
Ausgange der Mischer 2709 bzw. 2809 werden uber 2901 als 
Eingangsdaten an das Register gefuhrt. Je eine Registerbank 
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2902a/b verwaltet einen der Busse (Bl,B2,..Bm) des Knotens. Im 
Teil a einer Bank ist die Ansteuerung des Knotens gespeichert. 
In Teil b ist das Timeout der Busverbindung definiert. Teil b 
besteht aus einem ladbaren Zahler, dessen enable und reload 
Uber den Multiplexer 2903, einstellbar durch Teil a, gewahlt 
wird. 



Timeout-Prinzip 


Wirkung 


BUS-ACK 


Die Datentransfers werden gezahlt. 
(Bus in use / Paketgrofie) 


! BUS-ACK 
(invertiert) 


Die Takte ohne Datentransf er werden 
gezahlt. (Bus NOT not use / Timeout) 


en 


Jeder Takt wird gezahlt / Takt-Zyklen 




Kein Timeout / permanent 



Die Signale reload und enable des Zahlers werden bie folgt 
generiert : 



Timeout-Prinzip 


reload (rid) 


enable (en) 


BUS-ACK 


nie 


bei Datentransfer 


! BUS-ACK 
(invertiert) 


bei Datentransfer 


ohne Datentransfer 


en 


nie 


standig 




me 


nie 



Dabei ist das fur einen Reload, also das Neuladen des Zahlers, 
benotigte Register, das den ursprunglich gesetzten Zahlerstand 
enthalt in 2902b enthalten. 2904 testet auf den Zahlerstand 0 
urn den Timeout f estzustellen. 2904 ist in der Figur nur des 
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Verstandnis halber aufgezeigt; in der Implementierung wird das 
Obertragssignal (Ripple-Carry) des Zahlers verwendet. Der 
Obertrag loscht den Inhalt von 2902a, welches danach die 
Zustandsinformation "Bus-frei" weitergibt und somit den Bus 
abreifit. Aus dem Obertrag wird als Signal BUS-DISCONNECT auf 
den Bus geschaltet und zum Abrili der restlichen Bussegment 
verwendet. BUS-RECONF wird gemafi DE 197 04 728.9 mit den Daten 
mitgefuhrt und bewirkt bei Auftreten ebenfalls den Abrili des 
Busses. Ober das ODER-Gatter 2905 werden beide Signale 2902 
zugefuhrt und bewirken das Loschen des Registers und Zahlers, 
Der Timeout wird deaktiviert, indem gemafi den vorher 
aufgefuhrten Tabellen das enable-Signal deaktiviert ist und 
der Zahler mit einem Wert grofier null geladen wird. 
Die Daten in dem Register sind busorientiert , nicht 
schaltelementorientiert . Diese Daten gelangen uber 2906 an die 
Mischer 2709 und 2809. Jedes Steuersignal kommt m-fach (Anzahl 
der Busse) vor und wird in der Notation Si, m bezeichnet, wobei 
m fur den Bus und i far die Nummer des Schaltelements steht. 
Bevor die Daten an eine Matrix gemafi Figur 2 6 oder an einen 
Knoten gemafi den Figuren 23/24 gefuhrt werden miissen diese in 
der Art abgebildet werden, dafi lediglich eine Folge T A 
existiert. Die Abbildungsvorschrif t lautet dabei Ti = (S i( i u 
Si, 2 v S i#3 u ... v S i#m ) , mit anderen Worten alle S i# i bis S i/m 
werden verODERt. 2907 ubernimmt diese Funktion und fuhrt T 
uber 2908 den Matrizen und Schaltelementen zu. 

Figur 30 zeigt ein Beispiel fur zwei Busverbindungen. 

Konf igurierbaren Elementen oder Gruppen von konf igurierbaren 
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Elementen (3001) ist ein Knoten 3002 zugeordnet. Der Knoten 
3003 iibertragt Daten zum Knoten 3004. Der Verbindungsaufbau 
ist statisch. Der Knoten 3005 iibertragt die Daten dynamisch an 
den Zielknoten 3008. Dabei sind die Segmente 3006 und 3007 
belegt, sodafi sich die Laufrichtung jeweils andert. Die X/Y- 
Raumkoordinaten sind in den jeweilig durchlauf enen Knoten 
angegeben. Dabei werden die Koordinaten je nach Laufrichtung 
gleichbehalten, urn eins erhoht oder verringert. Anhand des 
Zahlenwertes der Koordinaten kann die Laufrichtung und das 
Ziel ausgemacht werden. Dabei wird aus der Position (A, B, C, 
D) des eingehenden Busses am Knoten und dem Vorzeichen der 
(X/Y)- Bewegung die Abweichung der Bewegungsrichtung 
berechnet. Dabei werden Himmelsrichtungen zur Bezeichnung 
verwendet, wobei y die Nord-Sud Achse und x die Ost-West Achse 
bildet : 



Laufrichtung 


Bewegung in 
Himmelsrichtung 


y = 0 


x > 0 => 0 
x < 0 => W 


y > 0 


N 


y < 0 


S 


x = 0 


y > 0 =s> N 
y < 0 => S 


x > 0 


0 


x < 0 


W 
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Anhand der Laufrichtung und der Himmelrichtung des eingehenden 
Busses kann berechnet werden, welches der Schaltelemente 
(1,2,3,4,5,6) angesprochen wird. Beide oben genannten 
Berechnungen sind trivial, so dafi die notwendige 
Berechnungseinheit (XY2ADR) beispielsweise durch Lookup- 
Tabellen ausgestaltet werden kann. Daher wird auf die 
Berechnung nicht weiters eingegangen, sondern auf die oben 
gezeigte Tabelle verwiesen. 

Die Adressierung in diesem Beispiel ist relativ. 

Figur 31 zeigt dasselbe Beispiel mit absoluten Koordinaten. Im 
Gegensatz zu Figur 30 werden die Koordinaten in den Knoten 
nicht berechnet, sondern mit den Koordinaten der Knoten gemaft 
dem ubergeordneten Koordinatensystem 3101 verglichen. Anhand 
der Vergleiche, grower (>) , kleiner (<) und gleich (=) wird 
der Verbindungsaufbau gesteuert. Sind beide Koodinaten (X und 
Y) gleich den Koordinaten des Knotens, ist das Ziel erreicht, 
ist eine Koordinate gleich der Koordinate des Knotens, ist die 
Zielachse der Koordinate erreicht. 

Die in den Figuren 30 und 31 aufgefuhrten Beispiele lassen 
keine Abweichung von der optimalen Richtung zu. Ware 
beispielsweise das Segment 3009 in Figur 30 belegt, konnten 
die Daten nicht weiter transferiert werden. Es ist moglich im 
Besetzt-Fall eine Abweichung von der vorgegebenen Richtung 
zuzulassen. Dann konnte die Verbindung liber 3010 aufgebaut 
werden. Allerdings muB der Raum fur eine mogliche Abweichung 
begrenzt werden, urn keine unsinnigen Routingversuche zu 
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erhalten. Eine sinnvolle Schranke fur Abweichungen von der 
vorgegebenen Richtung iiegt bei +/-1 bis + /-2. 

Figur 32a und 32b zeigen die notwendige Peripherie urn einen 
Knoten 3201, urn die Raumkoordinaten auszuwerten, bzw. zu 
modif izieren . 

Figur 32a modifiziert relative Koordinaten entsprechend ihrer 
Lauf richtung. In positiver Richtung wird subtrahiert (3203) , 
in negativer Richtung addiert (3202). Die Vergleicher (3204) 
stellen prlifen, ob eine Koordiante 0 erreicht hat, 
Figur 32b vergleicht absolute Koordinaten mit den Koordinaten 
des Knotens, mittels der Vergleicher 3205. 
Urn eine Abweichung von der vorgegebenen Richtung zu 
ermog lichen, werden die Vergleicher 3205 und 3204 so 
erweiterr, dafi sie die Information, ob sich eine Koordinate im 
Abweichungbereich befindet uberprufen und weitergeben 
(-Abweichung<Koordinate<Abweichung) . Anhand dieser Information 
kann die Berechnungseinheit (XY2ADR) bei einer Kollision der 
vorgegebenen Richtung, die Bewegungsrichtung innerhalb der 
Grenzen der zulassigen Abweichung modifizieren und eine 
Abweichung zulassen oder verhindern. Auch diese Berechnung ist 
trivial und kann ggf . durch Erweiterung der Lookup-Tabellen 
durchgefuhrt werden, in der nachf olgenden Tabelle ist die 
maximal zulassige Abweichung durch A angegeben: 
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Lauf richtung 


Bewegung in 
Himmelsricht* una 

1 A ^* W -L. W I 1 \-r Lilly 


y-A = 0 


X+A > U w U 

x-A < 0 => W 


y+A > 0 


N 


y-A < 0 


S 


x-A = 0 


y+A > 0 => N 
y-A < 0 => S 


x+A > 0 


0 


x-A < 0 


W 



Die Umgebung von x und y wird dabei unscharf, d.h. es ist 
moglich, daft Bewegungen in entgegengesetzte Himmelsrichtungen 
zulassig werden, da gleichzeitig k-A<0 UND k+A>0 gelten kann. 
Dies kann wenn gewiinscht eingegengt werden, indem keine 
Lauf richtung entgegen des Vorzeichens von k zugelassen wird. 
Ist k = 0 sind alle Lauf richtungen zugelassen. 

Figur 33 zeigt das Verhalten eines segmentierten Busses. Der 
Aufbau der Zeichnung entspricht dem bereits bekannten. Ein 
Senderknoten Sa sendet Daten an den Empf anger kont en Ea, ein 
weiterer Senderknoten Sb sendet an Eb und ein Letzter Sc an 
Ec, der auch der Empf angerknoten Eb ist. Dabei treten an den 
Segmenten 3301 und 3302 Kollisionen auf. Zur optimalen 
Ausnutzung des Busses (abgesehen davon, daft prinzipiell eine 
andere Wegfuhrung moglich ware) werden alle Busse quasi- 
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permanent aufgebaut; mit Ausnahme der Segmente 3301 und 3302. 
Diese Segmente arbeiten in dem Modus "Registered" und 
arbitrieren gemafi dem eingestellten Timeout je einen der 
anstehenden Busse. Ober den jeweiligen Timeout kann die 
Prioritat der einzelnen Busse festgelegt werden. Ein 
relevanter Bus erhalt grofie "Timout-Rechte" , also lange 
Zyklen, wahrend einem irrelevanten Bus kurze Zyklen zur 
Verfugung stehen. 

Die bisherigen Beschreibungen der Knoten in den Figuren 23-27 
zeigen der Vereinf achung halber nur die Vernetzung in die vier 
Himmelsrichtungen. Tatsachlich mussen in einem Knoten jedoch 
zusatzlich jeweils eine konf igurierbare Zelle oder eine Gruppe 
von konfigurierbaren Zellen auf geschaltet werden. Die hierfur 
notwendigen Erweiterungen sind in Figur 34 dargestellt. Die 
Kennzeichnungen der Knoten entsprechen in Figur 34a der Figur 
23 und in Figur 34b der Figur 24; der Anschlufi der 
konfigurierbaren Elemente ist mit Z gekennzeichnet . Die Matrix 
2603 ist gemafi Figur 34c zu 3401 zu andern. Die Anderung der 
Verschaltung erfolgt entsprechend Fig. 26. 

Die vorgestellten Beispiele sind der Verstandlichkeit halber 
auf 2-dimensionale Systeme ausgelegt. Auf Grundlage der 
vorgestellten Verfahren sind entsprechend komplexe beliebig 
mehrdimensionale Systeme baubar. 
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Begrif fsdef inition 

Address -Lookup Die Adresse wird nicht berechnet, sondern 

durch "nachsehen" in einem Speicher generiert. 

ALU Arithmetisch logische Einheit. Grundeinheit zum 

Verarbeiten von Daten. Die Einheit kann arithmetische 
Operationen wie Addition, Subtraktion, unter Umstanden auch 
Multiplikation, Division, Reihenentwicklungen usw. durch\- 
fuhren. Dabei kann die Einheit als ganzzahlige (integer) 
Einheit oder als Flieiikomma- (floating-point ) -Einheit gestaltet 
sein. Ebenfalls kann die Einheit logische Operationen, wie 
UND, ODER, sowie Vergleiche durchfuhren. 

Aufbauphase Zyklus wahrend dessen ein Bussegment aufgebaut 
wird. 

Arbiter Einheit urn Rechte zwischen Signalen zu verteiien. 

bidirektional Datenubertragung in beide Richtungen 

(Quelle/Ziell <-> Quelle/Ziel2) 

Broadcast Senden von Daten einer PAE an mehrere oder alle 

Da tenempf anger. 

Busanforderung Die Anforderung eine Busverbindung zum 

Datentransfer aufzubauen. (Auch Verbindungsanf orderung) 
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Bussegment Abschnitt eines Bussystems zwischen zwei 

Knot en 

Buszustande Art und Weise wie ein Bus arbeitet. Es wird 
zwischen zwei Hauptzustanden unterschieden : 

Quasi-permanent: Der Bus verhalt sich wie eine durchgehende 
Leitung. Der Bus ist nur von einem Datenpaket verwendbar (bis 
zu seinem Abriss) . 

Registered: Zwischen jedem Segment ist ein Register 
eingeschleift, das die Daten urn einen Taktzykius verzogert. 
Bei jedem Taktzykius (abhangig von Timeout) kann ein anderes 
Datenpaket arbitriert werden. 

Eine Mischung der beiden Zustande ergibt den Zustand 
Segmentiert, der beide Vorteile miteinander verbindet. 

Datenempf anger Die Einheit(en), die Ergebnisse der PAE 
weiterverarbeitet/-arbeiten} 

Datensender Die Einheit(en), die Daten fur die PAE als 

Operanden zur Verfugung stellt /stellen } 

Datentyp Art der Daten: Zeichen, Zahlen, 

Flieftkommazahlen, Signale (boolean), etc. 

Dezimaldekoder Wandelt ein binares Signal in ein 

Dezimales urn. 
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DFP Datenfluflprozessor nach Patent/Of fenlegung DE 44 16 

881 

DISCONNECT Von Timeout-Zahlern/Generatoren generiertes 
Signal zum Abriss eines Busses. Wirci an alle Knoten eines 
Busses gefuhrt. 

DPGA Dynamisch konf igurierbare FPGAs . Stand der Technik 

EALU Erweiterte arithmetisch logische Einheit. ALU, die 

urn Sonderfunktionen, die zum Betrieb einer 

Datenverarbeitungseinrichtung gemaft DE 441 16 881 Al benotigt 
werden oder sinnvoll sind erweitert wurde. Dies sind ins 
besondere Zahler. } 

Elemente Sammelbegrif f fur alle Arten von in sich 
abgeschlossenen Einheiten, welche als Stuck in einem 
elektronischen Baustein zum Einsatz kommen konnen. Elemente 
sind also: 

- Konf igurierbare Zellen aller Art 

- Cluster 

- RAM-B16cke 

- Logik 

- Rechenwerke 

- Register 

- Multiplexer 

- I/O Pins eines Chips 
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Enable Freischalten eines Registers oder Zahlers. 

FPGA Programmierbarer Logikbaustein. Stand der Technik. 

Gatter Gruppe von Transistoren, die eine logische 
Grundfunktion durchfuhren. Grundf unktionen sind z.B. NAND, 
NOR, Transmission-Gates . 

Geschwindigkeitsoptimiert Ein Bussystem, das meist quasi- 
permanent aufgebaut ist, eine hohe Prioritat besitzt und nicht 
von anderen Zugriffen beeinflufit wird. 

H-Pegel Logisch 1 Pegel, abhangig von der verwendeten 
Technologie 

Knoten Element das mehrere Bussegmente miteinander 
verbindet und den Verbindungsaufbau aktiv steuert, wahrend des 
Datentransfers jedoch passiv ist. 

konfigurierbares Element Ein konf igurierbares Element stellt 
eine Einheit eines Logik-Bausteines dar, welche durch ein 
Konf igurationswort fur eine spezielle Funktion eingestellt 
werden kann. Konf igurierbare Elemente sind somit, alle Arten 
von RAM-Zellen, Multiplexer, Arithmetische logische Einheiten, 
Register und alle Arten von interner und externer 
Vernetzungsbeschreibung etc. 

konfigurierbare Zelle Siehe Logikzellen 
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Konfigurieren Einstellen der Funktion und Vernetzung einer 
logischen Einheit, einer (FPGA)-Zelle oder einer PAE (vgl. 
umkonfigurieren) . 

Ladelogik Einheit zum Konfigurieren und Umkonfigurieren 

der PAE . Ausgestaltet durch einen speziell an seine Aufgabe 
angepafiten Mikrokontroller . 

Latch Speicherelement, das ein Signal fur gewohnlich 

wahrend des H-Pegels transparent weiterleitet und wahrend des 
L-Pegels speichert. In PAEs werden teilweise Latches 
gebraucht, bei denen die Funktion der Pegel genau umgekehrt 
ist. Hierbei wird vor den Takt eines ublichen Latch ein 
Inverter geschaltet. 

Logikzellen Bei DFPs, FPGAs , DPGAs verwendete 

konfigurierbare Zellen, die einfache logische oder 
arithmetische Aufgaben gemaB ihrer Konf iguration erfullen. 

LookUp-Tabelle (LUT) Tabelle, die einen Wert als Adresse 

erhalt und ein Ergebnis zurucklief ert . Beispielsweise wird 
eine Zahl als Adresse angegeben und. deren sinus wird 
zuruckgegeben. 

L-Pegel Logisch 0 Pegel, abhangig von der verwendeten 
Technologie 
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M-PLUREG Register in dem die Vernetzung der PAE gesetzt 

wird. Das Register wird von der PLU beschrieben. 

Maske Eine Bitkombination, die angibt, welche Signale 
einer Quelle weitergeleitet werden und welche Signale 
unterbrochen (ausmaskiert ) werden. 

Mischer Einheit zum Verschalten mehrerer Signale nach einer 
bestimmten Abbildungsvorschrif t . 

a) Fur gewohnlich finder eine logische Operation (UND/ODER) 
statt, cder 

b) die Signale werden zu einem Bus zusammengef aBt , wobei evtl. 

c) mehrere Signalquellen liber mehrere Multiplexer selektiv 
zusammengef alit werden. 

Open-Kollektor Schaltungstechnik, bei der der Kollektor eines 
Transistors an einem, uber einen Pullup auf den H-Pegel 
gezogenen, Bussignal liegt. Der Emitter der Transistors liegt 
auf Masse. Schaltet der Transistor, so wird das Bussignal auf 
den L-Pegel gezogen. Vorteil des Verfahrens ist, dafi eine 
Mehrzahl solcher Transistoren den Bus ohne elektrische 
Kollision steuern konnen. Dabei sind die Signale ODER- 
verkiipft, es entsteht das sog. wired-OR. 

PAE Processing Array Element: EALU mit O-REG, R-REG, 

R20-MUX, F-PLUREG, M-PLUREG, BM-, SM-, Sync-, StateBack- und 
Power-UNIT. 
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Partnerknoten Knoten mit dem ein bestimmter Knoten uber 

ein Bussegment Kontakt hat oder aufbauen will. 

PLU Einheit zum Konf igurieren und Umkonf igurieren der 

PAE. Ausgestaltet durch einen speziell an seine Aufgabe 
angepaftten Mikrokontroller . 

Prioritatsart Art und Weise, wie eine Prioritatskennung 

ausgewertet wird, 

Prioritatsdekoder Das Signal mit der hochsten Prioritat 

wird weitergegeben oder f reigeschaltet . 

Prioritatskennung Angabe der Prioritat sebene (hoch bis 

nieder) einer Busverbindung. 

Priority-Logik Das Signal mit der hochsten Prioritat wird 

weitergegeben oder f reigeschaltet . 

PullDown Widerstand, der eine Busleitung auf einen L-?egel 
zieht . 

PullUp Widerstand, der eine Busleitung auf einen H-Pegel 
zieht. 
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Quellenoptimiert Ein Bussystem, das meist registered und 
mit niederen Prioritaten aufgebaut ist, urn moglichst vielen 
Datensendern (Quellen) den Zugriff auf den Bus zu ermoglichen. 

Raumkoordinaten Angabe von Punkten mittels eines 
mehrdimensionalen Koordinatensystemes . Es konnen absolute 
Koordinaten (exakte Adresse eines Punktes) Oder relative 
Koordinaten (relative Entfernung von einem Ausgangspunkt) 
verwendet werden. Eine Bewegung in positiver Richtung erhoht 
den Zahlenwert einer Koordiante, eine Bewegung in negativer 
Richtung verringert den Zahlenwert einer Koordinate. 

RECONFIG Von konf igurierbaren Elementen generiertes 

Signal das anzeigt, daft die Elemente umkonf iguriert werden 
kGnnen und ihre Aktivitat beendet haben. Wird zum Abriss aller 
beteiligten Busses verwendet und an alle Knoten eines Busses 
gef iihrt . 

Registerbank Zusammenf assung mehrerer in Grofier und 

Funtkion unterschiedlicher Register zu einer Gruppe. 

Register-Bypass Leitung zum Umgehen eines Registers, 
dadurch wird der Synchronisationsef f ekt des Registers 
ausgeschaltet . 

RELOAD Neuladen eines Zahlers mit seinem ursprunglich 
gesetzten Wert. 
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Routingtabelle Tabelle innerhalb eines Knotens, die 

Informationen uber auf zubauende Verbindungen enthalt. 

Round-Robin-Arbiter Arbiter, der der Reihe nach ein 

Signal nach dem anderen f reischaltet . Das aktuell 
freigeschaltete Signal bekommt die niederste Prioritat und 
wird als Letztes in der Kette dann wieder f reigeschaltet . Der 
Arbiter arbeitet im Kreis. 

Sammelschiene Bus auf dem mehrere Bussegmente zusammengef uhrt 
werden. 

Schmitt-Trigger Fensterkomparator , der iiber eine Hysterese 
einem Signal genau einen von zwei Werten zuweist und dadurch 
die Signalqualitat verbessert. 

Switching-Tabelle Eine Switching-Tabelle ist ein Ring- 

Speicher, welcher durch eine Steuerung angesprochen wird. Die 
Eintrage einer Switching-Tabelle konnen beliebige 
Konf igurationsworter aufnehmen. Die Steuerung kann Befehle 
durchfuhren. Die Switching-Tabelle reagiert auf Triggersignale 
und konfiguriert konf igurierbare Elemente anhand eines 
Eintrages in einem Ringspeicher um. 

Timeout-Generator Einheit zum Generieren eines Timeouts nach 
unterschiedlichen Kriterien, wie 

- Taktzyklen ohne erfolgten Verbindungsaufbau 

- ubertragene Datenpakete 
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- Taktzyklen 

- Taktzyklen ohne Obertragung 

Timeout Nach Ablauf einer bestimmten Zeit geschieht 

etwas (ein Vorgang wird begonnen oder unterbrochen) . 

Timeout-Zahler siehe Timeout-Generator 

Tor Schalter, der ein Signal weiterleitet oder sperrt. 

Einfacher Vergleich: Relais 

unidirektional Datenubertragung in eine Richtungen 

(Quelle -> Ziel) 

Umkonf igurieren Neues Konf igurieren von einer 

beliebigen Menge von PAEs wahrend eine beliebige Restmenge von 
PAEs ihre eigenen Funktionen fortsetzen (vgl. konf igurieren) . 

Verbindungsanforderung Die Anforderung eine 

Busverbindung zum Datentransf er aufzubauen. (Auch 
Busanforderung) 

Zellen Synonym fur konf igurierbare Elemente 

Zielachse Die X/Y-Achse an der X = 0 ist oder X = Achse, 

bzw. Y = 0 oder Y = Achse ist die Zielachse von X bzw. Y. 
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Zustandsmaschine Logik, die diversen Zustande annehmen 

kann. Die Ubergange zwischen den Zustanden sind von 
verschiedenen Eingangsparametern abhangig. Diese Maschinen 
werden zur Steuerung komplexer Funktionen eingesetzt und 
entsprechen dem Stand der Technik 
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Namenskonvention 



Baugruppe -UNIT 
Betriebsart -MODE 
Multiplexer -MUX 
Negiertes Signal riot- 
Register far PLU sichtbar -PLUREG 
Register intern -REG 
Schieberegisters -sft 



Funkt ions konvent ion 
NICHT-Funktion ! 
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UND-Funktion & 
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ODER-Funktion #, > 
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Patent anspruche 

1. Bussystem fur DFPs gemafl DE 44 16 881 Al, sowie Bausteine 
mit zwei- oder mehrdimensionaler programmierbarer Zellstruktur 
(der Gattungen FPGA, DPGA, o.dgl.), dadurch gekennzeichnet, 
dafi 

a) das Bussystem aus einer Vielzahl voneinander 
elektrisch unabhangiger Bussegmente besteht, die liber 
Knoten getrennt sind, 

b) die Knoten Bussegmente aktiv zusammenfugen oder 
trennen, wobei 

bl) entweder zum Zusammenfugen mehrere Bussgmente 
uber Tore auf eine, sich innerhalb des Knoten 
befindende Sammelschiene zusammengeschaltet 
werden, oder 

b2) die Zusammenf ligung direkt uber Schaltelemente, 
Treiber und/oder Register erfolgt, 

c) jeder Knoten eine Routingtabelle besitzt, in der die 

Inf ormationen uber den Aufbau der Verbindungen 
gespeichert sind, 

d) jeder Knoten eine Uberwachungseinheit besitzt, die 

selbstandig priift ob eine Verbindung aufgebaut werden 
kann oder nicht. 

2. Bussystem nach Patentanspruch 1, dadurch gekennzeichnet, 
dafi 

eine Busverbindung schrittweise aufgebaut wird, wobei der 
Datensender zunachst nur die Verbindung zu dem mit ihm 
verbundenen Knoten herstellt, der Knoten dann uber seine 
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Routingtabelle feststellt, welcher ihm benachbarte Knoten fur 
die Verbindung benotigt wird und zu diesem uber das 
verbindende Bussegment Verbindung aufnimmt, sofern dieses 
nicht bereits von einer anderen Verbindung belegt ist; ist 
dies der Fall, so wird der Aufbau der Busverbindung 
abgebrochen oder ausgesetzt; ist dies nicht der Fall, so setzt 
der angesprochene Knoten den Aufbau der Busverbindung fort. 

3. Bussystem nach Patentansspruch 1, dadurch gekennzeichnet, 
daii 

ein Bussegment zur Obertragung eines Datenpaketes aufgebaut 
wird, wobei der Datensender zunachst die Verbindung zu dem mit 
ihm verbundenen Knoten herstellt, der Knoten dann uber seine 
Routingtabelle feststellt, welcher ihm benachbarte Knoten fur 
die Verbindung benotigt wird und die Daten uber das 
entspechende Bussegment weiterleitet, sofern dieses nicht 
bereits von einer anderen Verbindung belegt ist; ist dies der 
Fall, so wird der Aufbau der Busverbindung ausgesetzt; ist 
dies nicht der Fall, werden die Daten in dem Knoten geloscht 
und von dem benachbarten Knoten weiterverarbeitet . 

4. Bussystem nach Patentanspruch 1-3, dadurch gekennzeichnet, 
daB 

die Adressen der Daten oder der Verbindung in der Lookup- 
Tabelle eines Knotens auf die Adressen des nachsten Knotens 
libersetzt werden. 

5. Bussystem nach Patentanspruch 1-3, dadurch gekennzeichnet, 
daB 
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die Aclressen der Daten oder der Verbindung in einer 
Berechnungseinheit eines Knotens so verrechnet werden, dali 
entweder die Adresse des nachsten Knotens errechnet wird oder 
liber die Lookup-Tabelle die Adressen des nachsten Knotens 
generiert werden. 

6. Bussystem nach Patent anspruch 1 bis 5, dadurch 
gekennzeichnet, dali 

bei einem f ehlgeschlagenen Verbindungsaufbau der Aufbau zu 
einem spateren Zeitpunkt erneut versucht wird. 

7. Bussystem nach Patentanspruch 1 bis 6, dadurch 
gekennzeichnet, dali 

nach einem erfolgten Verbindungsaufbau die Knoten passiv sind 
und der Datentransf er ausschlielilich von Datensender und 
Datenempf anger gesteuert werden. 

8. Bussystem nach Patentanspruch 1 bis 6, dadurch 
gekennzeichnet, dali 

ein Knoten aktiv die Daten zu dem nachsten Knoten ubertragt 
und die Synchronisation ubernimmt. 

9. Bussystem nach Patentanspruch 1 bis 8, dadurch 
gekennzeichnet, dali 

weder Datensender noch Datenempf anger, weder wahrend des 
Verbindungsaufbaus noch des Betriebs, Kenntniss uber das 
Bussystem haben und keinerlei aktiven Eingriff auf die Knoten 
nehmen. 
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10. Bussystem nach Patentanspruch 1 bis 9, dadurch 
gekennzeichnet, dafi 

die Knoten und deren Routingtabellen von einer Ladelogik 
konfiguriert und umkonf iguriert werden. 

11. Bussystem nach Patentanspruch 1 bis 10, dadurch 
gekennzeichnet, daJi 

uber die Routingtabellen Ruckineldungen an die Ladelogik 
gesendet werden konnen. 

12. Bussystem nach Patentanspruch 1 bis 11, dadurch 
gekennzeichnet , dafi 

ein Knoten Daten an mehrere andere Knoten gleichzeitig 
versenden kann (Broadcasting) , wobei die 

Synchronisationssignale der empfangenden Knoten einstellbar 
boolsche verkmipft und einstellbar maskiert an den sendenden 
Knoten zuruckgegeben werden. 

14. Verfahren zur Ubertragung von Daten in DFPs gemaft DE 44 16 
881 Al, sowie Bausteine mit zwei- oder mehrdimensionaler 
programmierbarer Zellstruktur (der Gattungen FPGA, DPGA, 
o.dgl.), dadurch gekennzeichnet, dafi 

die Ubertragung der Daten segmentweise auf einem 
mehrdimensionalen Bussystemen erfolgt, wobei die Segmente 
beliebig zusammengeschaltet werden konnen und die 
Dateniibertragung synchronisiert erfolgt. 

15. Verfahren nach Anspruch 14 dadurch gekennzeichet, daJJ 
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die Segmente der Busse fest zu einem durchgangigen 
unverzogerten Bussystem zusammengeschaltet werden. 

16. Verfahren nach Anspruch 14 dadurch gekennzeichet , dali 
die Segmente der Busse durch Register zeitverzogert und 
arbitriert verschaltet werden. 

17. Verfahren nach Anspruch 14 bis 16 dadurch gekennzeichet, 
daft 

die beide Verschaltungsverf ahren gemali den Abspruchen 15 und 
16 bei einer Verbindung vorkommen. 

18. Verfahren nach Anspruch 14 bis 17 dadurch gekennzeichet, 
dafi 

der Aufbau eines Busses durch Lookup-Tabellen gesteuert wird, 
in denen die Verbindungsdaten abgelegt sind, wobei in jeder 
Lookup-Tabelle der Eintrag der nachf olgenden Tabelle 
referenziert ist. 

19. Verfahren nach Anspruch 14 bis 17 dadurch gekennzeichet, 
dali 

der Aufbau des eines Busses durch die Angabe einer eindeutigen 
berechenbaren relativen oder absoluten Adresse des Zieles 
erfolgt . 

20. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet , dali 

eine vorliegende Aufbaurichtung nur gewechselt wird, wenn die 
Zielachse erreicht ist. 
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21. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet , daft 

eine vorliegende Aufbaurichtung gewechselt wird, sobald eine 
Blockade in der vorliegenden Aufbaurichtung auftritt. 

22. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet , daft 

kein Aufbau entgegen der Aufbaurichtung und liber die Zielachse 
hinaus erfolgt. 

23. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet , daft 

ein Aufbau entgegen der Aufbaurichtung und uber die Zielachse 
hinaus erfolgen kann, sofern sich die Abweichung innerhalb 
eines fest vorgegebenen Raumes bewegt. 

24. Verfahren nach Anspruch 14 bis 23 dadurch gekennzeichet, 
daft 

die beide Aufbauverf ahren gemaft den Abspruchen 18 und 19 bei 
einer Verbindung vorkommen. 

25. Verfahren nach Anspruch 14 bis 24 dadurch gekennzeichet, 
daft 

beim Auftreten mehrere Anf orderungen an einem Knoten die 
Anforderungen arbitriert werden. 

26. Verfahren nach Anspruch 14 bis 25 dadurch gekennzeichet, 
daft 
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beim Auftreten mehrere Anf orderungen eine Mehrzahl von 
Anforderungen zeitgleich behandelt werden. 

27. Verfahren nach Anspruch 14 bis 26 dadurch gekennzeichet , 
dali 

Daten liber ein Bussegment an einen nachsten Knoten gesendet 
werden und der nachste Knoten die Daten bestatigt. 

28. .Verfahren nach Anspruch 14 bis 26 dadurch gekennzeichet, 
dali 

Daten uber ein Bussegment an mehrere nachsten Knoten gesendet 
werden und die nachste Knoten die Daten bestatigen, wobei die 
Bestatigungssignale beliebig in boolscher Algebra verknupft 
werden. 

29. Verfahren nach Anspruch 14 bis 26 und 28 dadurch 
gekennzeichet , daft 

Daten liber ein Bussegment an mehrere nachsten Knoten gesendet 
werden und die nachste Knoten die Daten bestatigen, eine Maske 
zum ausmaskieren einzelner Bestatigungssignale existierr. 

30. Verfahren nach Anspruch 14 bis 28 dadurch gekennzeichet, 
dali 

die beide Ubertragungsverf ahren gemafc den Abspriichen 27 und 28 
bei einer Verbindung vorkommen. 

31. Verfahren nach Anspruch 14 bis 30 dadurch gekennzeichet, 
daii 
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ein bestehender Bus aufgrund eines Abrifl-Signales aufgelost 
wird, das an alle beteiligten Knoten geleitet wird. 

32. Verfahren nach Anspruch 14 bis 31 dadurch gekennzeichet , 
daii 

ein Abrifl-Sigtnal aufgrund einer Zeituberschreitung von einem 
Oder mehreren Knoten generiert wird und an alle beteiligten 
Knoten geleitet wird. 

33. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet , 
dafl 

eine Zeituberschreitung aufgrund eines Zeitraums erfolgt, 
indem keine Daten iibertragen wurden. 

34. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
dafl 

eine Zeituberschreitung aufgrund eines Zeitraums erfolgt, 
indem Daten iibertragen wurden. 

35. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
dafl 

eine Zeituberschreitung aufgrund der ubertragenen Datenmenge 
erfolgt. 

36. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
dafl 

eine Zeituberschreitung nicht moglich ist. 
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37. Verfahren nach Anspruch 14 bis 36 dadurch gekennzeichet, 
daii 

das verwendete Zeituberschreitungsverf ahren fur jedes 
Bussegment gemali den Anspruchen 33 bis 36 selektiv gewahlt 
wird. 
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